///*******************************************************************************
// * Copyright (c) 2000, 2010 IBM Corporation and others.
// * All rights reserved. This program and the accompanying materials
// * are made available under the terms of the Eclipse Public License v1.0
// * which accompanies this distribution, and is available at
// * http://www.eclipse.org/legal/epl-v10.html
// *
// * Contributors:
// *     IBM Corporation - initial API and implementation
// *******************************************************************************/
//package org.eclipse.ui.tests.api;
//
//import java.util.ArrayList;
//import java.util.Arrays;
//import java.util.HashMap;
//import java.util.HashSet;
//import java.util.List;
//import java.util.Set;
//
//import org.eclipse.core.commands.Command;
//import org.eclipse.core.commands.ExecutionException;
//import org.eclipse.core.commands.NotEnabledException;
//import org.eclipse.core.commands.NotHandledException;
//import org.eclipse.core.commands.ParameterizedCommand;
//import org.eclipse.core.commands.common.NotDefinedException;
//import org.eclipse.core.resources.IFile;
//import org.eclipse.core.resources.IMarker;
//import org.eclipse.core.resources.IProject;
//import org.eclipse.core.resources.IResource;
//import org.eclipse.core.runtime.IAdaptable;
//import org.eclipse.core.runtime.ILogListener;
//import org.eclipse.core.runtime.IStatus;
//import org.eclipse.core.runtime.Platform;
//import org.eclipse.jface.text.IDocument;
//import org.eclipse.jface.util.IPropertyChangeListener;
//import org.eclipse.jface.util.PropertyChangeEvent;
//import org.eclipse.ui.IEditorInput;
//import org.eclipse.ui.IEditorPart;
//import org.eclipse.ui.IEditorReference;
//import org.eclipse.ui.IMemento;
//import org.eclipse.ui.IPageLayout;
//import org.eclipse.ui.IPartListener2;
//import org.eclipse.ui.IPerspectiveDescriptor;
//import org.eclipse.ui.IPerspectiveRegistry;
//import org.eclipse.ui.IViewPart;
//import org.eclipse.ui.IViewReference;
//import org.eclipse.ui.IWorkbenchCommandConstants;
//import org.eclipse.ui.IWorkbenchPage;
//import org.eclipse.ui.IWorkbenchPartReference;
//import org.eclipse.ui.IWorkbenchWindow;
//import org.eclipse.ui.IWorkingSet;
//import org.eclipse.ui.IWorkingSetManager;
//import org.eclipse.ui.PartInitException;
//import org.eclipse.ui.PlatformUI;
//import org.eclipse.ui.WorkbenchException;
//import org.eclipse.ui.XMLMemento;
//import org.eclipse.ui.commands.ICommandService;
//import org.eclipse.ui.editors.text.EditorsUI;
//import org.eclipse.ui.editors.text.TextEditor;
//import org.eclipse.ui.handlers.IHandlerService;
//import org.eclipse.ui.ide.IDE;
//import org.eclipse.ui.internal.WorkbenchPlugin;
//import org.eclipse.ui.internal.tweaklets.Tweaklets;
//import org.eclipse.ui.internal.util.Util;
//import org.eclipse.ui.navigator.resources.ProjectExplorer;
//import org.eclipse.ui.part.FileEditorInput;
//import org.eclipse.ui.part.IPage;
//import org.eclipse.ui.tests.harness.util.CallHistory;
//import org.eclipse.ui.tests.harness.util.EmptyPerspective;
//import org.eclipse.ui.tests.harness.util.FileUtil;
//import org.eclipse.ui.tests.harness.util.UITestCase;
//import org.eclipse.ui.tests.helpers.TestFacade;
//import org.eclipse.ui.texteditor.ITextEditor;
//import org.eclipse.ui.views.contentoutline.ContentOutline;
//
//public class IWorkbenchPageTest extends UITestCase {
//
//	private IWorkbenchPage fActivePage;
//
//	private IWorkbenchWindow fWin;
//
//	private IProject proj;
//
//	private int logCount;
//	private IStatus logStatus;
//	String getMessage() {
//		return logStatus==null?"No message":logStatus.getMessage();
//	}
//	ILogListener openAndHideListener = new ILogListener() {
//		public void logging(IStatus status, String plugin) {
//			logStatus = status;
//			logCount++;
//		}
//	};
//
//
//	private int partHiddenCount = 0;
//	private IWorkbenchPartReference partHiddenRef = null;
//	private int partVisibleCount = 0;
//	private IWorkbenchPartReference partVisibleRef = null;
//	private int partActiveCount = 0;
//	private IWorkbenchPartReference partActiveRef = null;
//	IPartListener2 partListener2 = new IPartListener2() {
//		public void partActivated(IWorkbenchPartReference partRef) {
//			partActiveCount++;
//			partActiveRef = partRef;
//		}
//
//		public void partBroughtToTop(IWorkbenchPartReference partRef) {
//		}
//
//		public void partClosed(IWorkbenchPartReference partRef) {
//		}
//
//		public void partDeactivated(IWorkbenchPartReference partRef) {
//		}
//
//		public void partHidden(IWorkbenchPartReference partRef) {
//			partHiddenCount++;
//			partHiddenRef = partRef;
//		}
//
//		public void partInputChanged(IWorkbenchPartReference partRef) {
//		}
//
//		public void partOpened(IWorkbenchPartReference partRef) {
//		}
//
//		public void partVisible(IWorkbenchPartReference partRef) {
//			partVisibleCount++;
//			partVisibleRef = partRef;
//		}
//	};
//
//	private TestFacade facade;
//
//
//
//	public IWorkbenchPageTest(String testName) {
//		super(testName);
//	}
//
//	protected void doSetUp() throws Exception {
//		super.doSetUp();
//		fWin = openTestWindow();
//		fActivePage = fWin.getActivePage();
//		logStatus = null;
//		logCount = 0;
//		facade = (TestFacade) Tweaklets.get(TestFacade.KEY);
//		Platform.addLogListener(openAndHideListener);
//	}
//
//	protected void doTearDown() throws Exception {
//		super.doTearDown();
//		if (proj != null) {
//			FileUtil.deleteProject(proj);
//			proj = null;
//		}
//		Platform.removeLogListener(openAndHideListener);
//	}
//
//	/**
//	 * Tests the new working set API.
//	 *
//	 * @since 3.2
//	 */
//	public void testWorkingSets1() {
//		IWorkbenchPage page = fActivePage;
//		IWorkingSet[] sets = page.getWorkingSets();
//		assertNotNull(sets);
//		assertEquals(0, sets.length);
//
//		IWorkingSetManager manager = page.getWorkbenchWindow().getWorkbench()
//				.getWorkingSetManager();
//
//		IWorkingSet set1 = null, set2 = null;
//		try {
//			set1 = manager.createWorkingSet("w1", new IAdaptable[0]);
//			manager.addWorkingSet(set1);
//			set2 = manager.createWorkingSet("w2", new IAdaptable[0]);
//			manager.addWorkingSet(set2);
//
//			page.setWorkingSets(new IWorkingSet[] { set1 });
//			sets = page.getWorkingSets();
//
//			assertNotNull(sets);
//			assertEquals(1, sets.length);
//			assertEquals(set1, sets[0]);
//
//			page.setWorkingSets(new IWorkingSet[0]);
//			sets = page.getWorkingSets();
//			assertNotNull(sets);
//			assertEquals(0, sets.length);
//
//			page.setWorkingSets(new IWorkingSet[] { set1, set2 });
//			sets = page.getWorkingSets();
//
//			assertNotNull(sets);
//			assertEquals(2, sets.length);
//			Set realSet = new HashSet(Arrays.asList(sets));
//			assertTrue(realSet.contains(set1));
//			assertTrue(realSet.contains(set2));
//
//			page.setWorkingSets(new IWorkingSet[0]);
//			sets = page.getWorkingSets();
//			assertNotNull(sets);
//			assertEquals(0, sets.length);
//		} finally {
//			if (set1 != null)
//				manager.removeWorkingSet(set1);
//			if (set2 != null)
//				manager.removeWorkingSet(set2);
//		}
//	}
//
//	/**
//	 * Tests the new working set API.
//	 *
//	 * @since 3.2
//	 */
//	public void testWorkingSets2() {
//		fActivePage.setWorkingSets(null);
//		IWorkingSet[] sets = fActivePage.getWorkingSets();
//		assertNotNull(sets);
//		assertEquals(0, sets.length);
//	}
//
//	/**
//	 * Tests the working set listeners.
//	 *
//	 * @since 3.2
//	 */
//	public void testWorkingSets3() {
//		IWorkingSetManager manager = fActivePage.getWorkbenchWindow()
//				.getWorkbench().getWorkingSetManager();
//
//		IWorkingSet set1 = null;
//		final IWorkingSet[][] sets = new IWorkingSet[1][];
//		sets[0] = new IWorkingSet[0];
//		IPropertyChangeListener listener = new IPropertyChangeListener() {
//
//			public void propertyChange(PropertyChangeEvent event) {
//				IWorkingSet[] oldSets = (IWorkingSet[]) event.getOldValue();
//				assertTrue(Arrays.equals(sets[0], oldSets));
//				sets[0] = (IWorkingSet[]) event.getNewValue();
//			}
//		};
//		try {
//			set1 = manager.createWorkingSet("w1", new IAdaptable[0]);
//			manager.addWorkingSet(set1);
//
//			fActivePage.addPropertyChangeListener(listener);
//
//			fActivePage.setWorkingSets(new IWorkingSet[] { set1 });
//			fActivePage.setWorkingSets(new IWorkingSet[] {});
//			fActivePage.setWorkingSets(new IWorkingSet[] { set1 });
//
//			sets[0] = fActivePage.getWorkingSets();
//
//			assertNotNull(sets[0]);
//			assertEquals(1, sets[0].length);
//			assertEquals(set1, sets[0][0]);
//
//		} finally {
//			fActivePage.removePropertyChangeListener(listener);
//			if (set1 != null)
//				manager.removeWorkingSet(set1);
//		}
//	}
//
//	/**
//	 * Test the VIEW_VISIBLE parameter for showView, opening the view in the
//	 * stack that does not contain the active view. Ensures that the created
//	 * view is not the active part but is the top part in its stack.
//	 */
//	public void testView_VISIBLE2() throws PartInitException {
//		fActivePage.setPerspective(WorkbenchPlugin.getDefault()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//						"org.eclipse.ui.tests.api.ViewPerspective"));
//
//		// create a part to be active
//		IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
//
//		IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
//				IWorkbenchPage.VIEW_VISIBLE);
//
//		IViewPart[] stack = fActivePage.getViewStack(createdPart);
//		assertEquals(2, stack.length);
//
//		assertEquals(createdPart, stack[0]);
//		assertEquals(fActivePage.findView(MockViewPart.ID), stack[1]);
//
//		assertTrue(fActivePage.isPartVisible(createdPart));
//
//		assertEquals(activePart, fActivePage.getActivePart());
//	}
//
//	/**
//	 * openEditor(IEditorInput input, String editorId, boolean activate)
//	 */
//	public void testOpenEditor4() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		final String id = MockEditorPart.ID1;
//		IEditorInput input = new FileEditorInput(FileUtil.createFile(
//				"test.mock1", proj));
//		MockPartListener listener = new MockPartListener();
//		fActivePage.addPartListener(listener);
//		CallHistory callTrace = listener.getCallHistory();
//
//		/*
//		 * javadoc: The editor type is determined by mapping editorId to an
//		 * editor extension registered with the workbench. javadoc: If activate ==
//		 * true the editor will be activated
//		 */
//		// open an editor with activation
//		// Start with a view active in order to verify that the editor gets
//		// activated
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		callTrace.clear();
//		IEditorPart editor = IDE.openEditor(fActivePage, input, id, true);
//		assertEquals(editor.getEditorInput(), input);
//		assertEquals(editor.getSite().getId(), id);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//		assertEquals(callTrace.contains("partActivated"), true);
//
//		// we need another editor so that the editor under test can receive
//		// events.
//		// otherwise, events will be ignored.
//		IEditorPart extra = IDE.openEditor(fActivePage, FileUtil.createFile(
//				"aaaaa", proj));
//
//		// close the first editor after the second has opened; necessary for
//		// test to work with fix to PR 7743
//		fActivePage.closeEditor(editor, false);
//
//		// Start with a view active in order to verify that the editor does not
//		// get activated
//		// (note: regardless of the activate=false flag, the editor would always
//		// be activated
//		// if it is being opened in the same stack as the active editor. Making
//		// a view active
//		// initially tests the function of the activate flag)
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		callTrace.clear();
//		// open an editor without activation
//		editor = IDE.openEditor(fActivePage, input, id, false);
//
//		assertEquals(editor.getEditorInput(), input);
//		assertEquals(editor.getSite().getId(), id);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(callTrace.contains("partActivated"), false);
//		assertEquals(callTrace.contains("partBroughtToTop"), true);
//
//		fActivePage.activate(extra);
//
//		/*
//		 * javadoc: If this page already has an editor open on the target object
//		 * that editor is brought to the front
//		 */
//		// open the editor under test second time without activation
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		callTrace.clear();
//		assertEquals(IDE.openEditor(fActivePage, input, id, false), editor);
//		assertEquals(callTrace.contains("partBroughtToTop"), true);
//		assertEquals(callTrace.contains("partActivated"), false);
//
//		// activate the other editor
//		fActivePage.activate(extra);
//
//		/*
//		 * javadoc: If activate == true the editor will be activated
//		 */
//		// open the editor under test second time with activation
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		callTrace.clear();
//		assertEquals(IDE.openEditor(fActivePage, input, id, true), editor);
//		assertEquals(callTrace.contains("partBroughtToTop"), true);
//		assertEquals(callTrace.contains("partActivated"), true);
//
//		/*
//		 * javadoc: If activate == false but another editor in the same stack
//		 * was active, the new editor will be activated regardless.
//		 */
//		// Close the old editor
//		fActivePage.closeEditor(editor, false);
//		// Ensure another editor in the stack is active
//		fActivePage.activate(extra);
//		callTrace.clear();
//		// Verify that the editor is still activated
//		IDE.openEditor(fActivePage, input, id, false);
//		assertEquals(callTrace.contains("partBroughtToTop"), true);
//		assertEquals(callTrace.contains("partActivated"), true);
//	}
//
//	/**
//	 * tests both of the following: setEditorAreaVisible() isEditorAreaVisible()
//	 */
//	public void testGet_SetEditorAreaVisible() throws Throwable {
//		fActivePage.setEditorAreaVisible(true);
//		assertTrue(fActivePage.isEditorAreaVisible() == true);
//
//		fActivePage.setEditorAreaVisible(false);
//		assertTrue(fActivePage.isEditorAreaVisible() == false);
//	}
//
//	/**
//	 * openEditor(IWorkbenchPage page, IFile input)
//	 */
//	public void testOpenEditor() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//
//		/*
//		 * javadoc: 1. The workbench editor registry is consulted to determine
//		 * if an editor extension has been registered for the file type. If so,
//		 * an instance of the editor extension is opened on the file
//		 */
//		IFile file = FileUtil.createFile("test.mock1", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file);
//
//		boolean foundEditor = hasEditor(editor);
//		assertEquals(foundEditor, true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//		assertEquals(editor.getSite().getId(), fWorkbench.getEditorRegistry()
//				.getDefaultEditor(file.getName()).getId());
//
//		/*
//		 * javadoc: 2. Next, the native operating system will be consulted to
//		 * determine if a native editor exists for the file type. If so, a new
//		 * process is started and the native editor is opened on the file.
//		 */
//		// can not be tested
//		/*
//		 * javadoc: 3. If all else fails the file will be opened in a default
//		 * text editor.
//		 */
//
//		file = FileUtil.createFile("a.null and void", proj);
//		editor = IDE.openEditor(fActivePage, file);
//		if (editor != null) {//If it opened an external editor skip it (Vista issue)
//			assertEquals(hasEditor(editor), true);
//			assertEquals(fActivePage.getActiveEditor(), editor);
//			assertEquals(editor.getSite().getId(),
//					"org.eclipse.ui.DefaultTextEditor");
//
//			// open another editor to take the focus away from the first editor
//			IDE
//					.openEditor(fActivePage, FileUtil.createFile("test.mock2",
//							proj));
//
//			/*
//			 * javadoc: If this page already has an editor open on the target
//			 * object that editor is activated
//			 */
//			// open the editor second time.
//			assertEquals(editor, IDE.openEditor(fActivePage, file));
//			assertEquals(editor, fActivePage.getActiveEditor());
//		}
//	}
//
//	/**
//	 * openEditor(IWorkbenchPage page, IFile input, String editorID)
//	 */
//	public void testOpenEditor2() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		final IFile file = FileUtil.createFile("asfasdasdf", proj);
//		final String id = MockEditorPart.ID1;
//
//		/*
//		 * javadoc: The editor type is determined by mapping editorId to an
//		 * editor extension registered with the workbench.
//		 */
//		IEditorPart editor = IDE.openEditor(fActivePage, file, id);
//		assertEquals(editor.getSite().getId(), id);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//
//		// open another editor to take the focus away from the first editor
//		IDE.openEditor(fActivePage, FileUtil.createFile("test.mock2", proj));
//
//		/*
//		 * javadoc: If this page already has an editor open on the target object
//		 * that editor is activated
//		 */
//		// open the first editor second time.
//		assertEquals(IDE.openEditor(fActivePage, file, id), editor);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//	}
//
//	/**
//	 * openEditor(IEditorInput input,String editorId)
//	 */
//	public void testOpenEditor3() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		final String id = MockEditorPart.ID1;
//		IEditorInput input = new FileEditorInput(FileUtil.createFile(
//				"test.mock1", proj));
//
//		/*
//		 * javadoc: The editor type is determined by mapping editorId to an
//		 * editor extension registered with the workbench
//		 */
//		IEditorPart editor = IDE.openEditor(fActivePage, input, id);
//		assertEquals(editor.getEditorInput(), input);
//		assertEquals(editor.getSite().getId(), id);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//
//		// open another editor to take the focus away from the first editor
//		IDE.openEditor(fActivePage, FileUtil.createFile("test.mock2", proj));
//
//		/*
//		 * javadoc: If this page already has an editor open on the target object
//		 * that editor is activated
//		 */
//		// open the first editor second time.
//		assertEquals(IDE.openEditor(fActivePage, input, id), editor);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//	}
//
//	/**
//	 * openEditor(IMarker marker)
//	 */
//	public void testOpenEditor5() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		IMarker marker = FileUtil.createFile("aa.mock2", proj).createMarker(
//				IMarker.TASK);
//		CallHistory callTrace;
//
//		/*
//		 * javadoc: the cursor and selection state of the editor is then updated
//		 * from information recorded in the marker.
//		 */
//		// open the registered editor for the marker resource
//		IEditorPart editor = IDE.openEditor(fActivePage, marker);
//		callTrace = ((MockEditorPart) editor).getCallHistory();
//		assertEquals(editor.getSite().getId(), MockEditorPart.ID2);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//		assertEquals(callTrace.contains("gotoMarker"), true);
//		fActivePage.closeEditor(editor, false);
//
//		/*
//		 * javadoc: If the marker contains an EDITOR_ID_ATTR attribute the
//		 * attribute value will be used to determine the editor type to be
//		 * opened
//		 */
//		marker.setAttribute(IDE.EDITOR_ID_ATTR, MockEditorPart.ID1);
//		editor = IDE.openEditor(fActivePage, marker);
//		callTrace = ((MockEditorPart) editor).getCallHistory();
//		assertEquals(editor.getSite().getId(), MockEditorPart.ID1);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//		assertEquals(callTrace.contains("gotoMarker"), true);
//		// do not close the editor this time
//
//		/*
//		 * javdoc: If this page already has an editor open on the target object
//		 * that editor is activated
//		 */
//		callTrace.clear();
//		assertEquals(IDE.openEditor(fActivePage, marker), editor);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//		assertEquals(callTrace.contains("gotoMarker"), true);
//		fActivePage.closeEditor(editor, false);
//	}
//
//	/**
//	 * openEditor(IMarker marker, boolean activate)
//	 */
//	public void testOpenEditor6() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		IMarker marker = FileUtil.createFile("aa.mock2", proj).createMarker(
//				IMarker.TASK);
//		MockPartListener listener = new MockPartListener();
//		fActivePage.addPartListener(listener);
//		CallHistory listenerCall = listener.getCallHistory();
//		CallHistory editorCall;
//
//		// we need another editor so that the editor under test can receive
//		// events.
//		// otherwise, events will be ignored.
//		IEditorPart extra = IDE.openEditor(fActivePage, FileUtil.createFile(
//				"aaaaa", proj));
//
//		/*
//		 * javadoc: If activate == true the editor will be activated
//		 */
//		// open the registered editor for the marker resource with activation
//		IEditorPart editor = IDE.openEditor(fActivePage, marker, true);
//		editorCall = ((MockEditorPart) editor).getCallHistory();
//		assertEquals(editor.getSite().getId(), MockEditorPart.ID2);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//
//		/*
//		 * javadoc: the cursor and selection state of the editor is then updated
//		 * from information recorded in the marker.
//		 */
//		assertEquals(editorCall.contains("gotoMarker"), true);
//		fActivePage.closeEditor(editor, false);
//
//		fActivePage.activate(extra);
//
//		// open the registered editor for the marker resource without activation
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		listenerCall.clear();
//		editor = IDE.openEditor(fActivePage, marker, false);
//		editorCall = ((MockEditorPart) editor).getCallHistory();
//		assertEquals(editor.getSite().getId(), MockEditorPart.ID2);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(listenerCall.contains("partBroughtToTop"), true);
//		assertEquals(listenerCall.contains("partActivated"), false);
//		assertEquals(editorCall.contains("gotoMarker"), true);
//		fActivePage.closeEditor(editor, false);
//
//		/*
//		 * javadoc: If the marker contains an EDITOR_ID_ATTR attribute the
//		 * attribute value will be used to determine the editor type to be
//		 * opened
//		 */
//		String id = MockEditorPart.ID1;
//		marker.setAttribute(IDE.EDITOR_ID_ATTR, id);
//
//		// open an editor with activation
//		listenerCall.clear();
//
//		editor = IDE.openEditor(fActivePage, marker, true);
//		editorCall = ((MockEditorPart) editor).getCallHistory();
//		assertEquals(editor.getSite().getId(), id);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//		assertEquals(editorCall.contains("gotoMarker"), true);
//		fActivePage.closeEditor(editor, false);
//
//		fActivePage.activate(extra);
//
//		// open an editor without activation
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		listenerCall.clear();
//		editor = IDE.openEditor(fActivePage, marker, false);
//		editorCall = ((MockEditorPart) editor).getCallHistory();
//		assertEquals(editor.getSite().getId(), id);
//		assertEquals(hasEditor(editor), true);
//		assertEquals(editorCall.contains("gotoMarker"), true);
//		assertEquals(listenerCall.contains("partActivated"), false);
//		assertEquals(listenerCall.contains("partBroughtToTop"), true);
//		// do not close the editor this time
//
//		fActivePage.activate(extra);
//		/*
//		 * javadoc: If this page already has an editor open on the target object
//		 * that editor is brought to front Note: we need to make a non-editor
//		 * active first or bringing the editor to front would activate it
//		 */
//		// open the editor second time without activation
//		fActivePage.showView(IPageLayout.ID_PROBLEM_VIEW, null,
//				IWorkbenchPage.VIEW_ACTIVATE);
//		listenerCall.clear();
//		assertEquals(IDE.openEditor(fActivePage, marker, false), editor);
//		assertEquals(listenerCall.contains("partBroughtToTop"), true);
//		assertEquals(listenerCall.contains("partActivated"), false);
//
//		fActivePage.activate(extra);
//
//		/*
//		 * javdoc: If activate == true the editor will be activated
//		 */
//		// open the editor second time with activation
//		listenerCall.clear();
//		assertEquals(IDE.openEditor(fActivePage, marker, true), editor);
//		assertEquals(editorCall.contains("gotoMarker"), true);
//		assertEquals(listenerCall.contains("partBroughtToTop"), true);
//		assertEquals(listenerCall.contains("partActivated"), true);
//
//		/*
//		 * javadoc: If activate == false but another editor in the same stack
//		 * was active, the new editor will be activated regardless.
//		 */
//		// Close the old editor
//		fActivePage.closeEditor(editor, false);
//		// Ensure another editor in the stack is active
//		fActivePage.activate(extra);
//		listenerCall.clear();
//		// Verify that the editor is still activated
//		IDE.openEditor(fActivePage, marker, false);
//		assertEquals(listenerCall.contains("partBroughtToTop"), true);
//		assertEquals(listenerCall.contains("partActivated"), true);
//	}
//
//	/**
//	 * Tests that the marker's value for the <code>IDE.EDITOR_ID_ATTR</code>
//	 * attribute.
//	 */
//	public void testOpenEditor7_Bug203640() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		IFile file = FileUtil.createFile("aa.mock2", proj);
//		IMarker marker = file.createMarker(
//				IMarker.TASK);
//		marker.setAttribute(IDE.EDITOR_ID_ATTR, MockEditorPart.ID1);
//
//		// open a regular text editor
//		IEditorPart regularEditor = fActivePage.openEditor(new FileEditorInput(file), EditorsUI.DEFAULT_TEXT_EDITOR_ID);
//		assertNotNull(regularEditor);
//		assertTrue(regularEditor instanceof TextEditor);
//
//		// open the registered editor for the marker resource
//		IEditorPart markerEditor = IDE.openEditor(fActivePage, marker);
//		assertNotNull(markerEditor);
//		assertTrue(markerEditor instanceof MockEditorPart);
//
//		// these shouldn't be the same, if they are it's a bug
//		assertFalse(markerEditor == regularEditor);
//		assertFalse(markerEditor.equals(regularEditor));
//		assertEquals(2, fActivePage.getEditorReferences().length);
//	}
//
//	public void testGetPerspective() throws Throwable {
//		assertNotNull(fActivePage.getPerspective());
//
//		IWorkbenchPage page = fWin.openPage(EmptyPerspective.PERSP_ID,
//				getPageInput());
//		assertEquals(EmptyPerspective.PERSP_ID, page.getPerspective().getId());
//	}
//
//	public void testSetPerspective() throws Throwable {
//		IPerspectiveDescriptor per = PlatformUI.getWorkbench()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//						EmptyPerspective.PERSP_ID);
//		fActivePage.setPerspective(per);
//		assertEquals(per, fActivePage.getPerspective());
//	}
//
//	public void testGetLabel() {
//		assertNotNull(fActivePage.getLabel());
//	}
//
//	public void testGetInput() throws Throwable {
//		IAdaptable input = getPageInput();
//		IWorkbenchPage page = fWin.openPage(input);
//		assertEquals(input, page.getInput());
//	}
//
//	public void testActivate() throws Throwable {
//		MockViewPart part = (MockViewPart) fActivePage
//				.showView(MockViewPart.ID);
//		MockViewPart part2 = (MockViewPart) fActivePage
//				.showView(MockViewPart.ID2);
//
//		MockPartListener listener = new MockPartListener();
//		fActivePage.addPartListener(listener);
//		fActivePage.activate(part);
//
//		CallHistory callTrace;
//
//		callTrace = part2.getCallHistory();
//		callTrace.clear();
//		fActivePage.activate(part2);
//		assertTrue(callTrace.contains("setFocus"));
//		assertTrue(listener.getCallHistory().contains("partActivated"));
//
//		callTrace = part.getCallHistory();
//		callTrace.clear();
//		fActivePage.activate(part);
//		assertTrue(callTrace.contains("setFocus"));
//		assertTrue(listener.getCallHistory().contains("partActivated"));
//	}
//
//	public void testBringToTop() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		IEditorPart part = IDE.openEditor(fActivePage, FileUtil.createFile(
//				"a.mock1", proj));
//		IEditorPart part2 = IDE.openEditor(fActivePage, FileUtil.createFile(
//				"b.mock1", proj));
//
//		MockPartListener listener = new MockPartListener();
//		fActivePage.addPartListener(listener);
//		CallHistory callTrace = listener.getCallHistory();
//
//		// at this point, part2 is active
//		fActivePage.bringToTop(part);
//		assertEquals(callTrace.contains("partBroughtToTop"), true);
//
//		callTrace.clear();
//		fActivePage.bringToTop(part2);
//		assertEquals(callTrace.contains("partBroughtToTop"), true);
//	}
//
//	/**
//	 * Test to ensure that a minimized view can be brought to the top and
//	 * consequently made visible.
//	 *
//	 * @param hasEditors whether there should be editors open or not
//	 */
//	private void testBringToTop_MinimizedViewBug292966(boolean hasEditors) throws Throwable {
//		// first show the view we're going to test
//		IViewPart propertiesView = fActivePage.showView(IPageLayout.ID_PROP_SHEET);
//		assertNotNull(propertiesView);
//
//		proj = FileUtil.createProject("testOpenEditor");
//		// open an editor
//		IEditorPart editor = IDE.openEditor(fActivePage, FileUtil.createFile(
//				"a.mock1", proj));
//		assertNotNull("The editor could not be opened", editor); //$NON-NLS-1$
//		assertTrue("The editor is not visible", fActivePage.isPartVisible(editor)); //$NON-NLS-1$
//
//		if (!hasEditors) {
//			// close editors if we don't want them opened for this test
//			fActivePage.closeAllEditors(false);
//			assertEquals("All the editors should have been closed", 0, fActivePage.getEditorReferences().length); //$NON-NLS-1$
//		}
//
//		// minimize the view we're testing
//		fActivePage.setPartState(fActivePage.getReference(propertiesView), IWorkbenchPage.STATE_MINIMIZED);
//		assertFalse("A minimized view should not be visible", fActivePage.isPartVisible(propertiesView)); //$NON-NLS-1$
//
//		// open another view so that it now becomes the active part container
//		IViewPart projectExplorer = fActivePage.showView(IPageLayout.ID_PROJECT_EXPLORER);
//		// get the list of views that shares the stack with this other view
//		IViewPart[] viewStack = fActivePage.getViewStack(projectExplorer);
//		// make sure that we didn't inadvertently bring back the test view by mistake
//		for (int i = 0; i < viewStack.length; i++) {
//			assertFalse("The properties view should not be on the same stack as the project explorer", //$NON-NLS-1$
//					viewStack[i].getSite().getId().equals(IPageLayout.ID_PROP_SHEET));
//		}
//
//		// bring the test view back from its minimized state
//		fActivePage.bringToTop(propertiesView);
//		// the view should be visible
//		assertTrue("Invoking bringToTop(IWorkbenchPart) should cause the part to be visible", //$NON-NLS-1$
//				fActivePage.isPartVisible(propertiesView));
//	}
//
//	public void testBringToTop_MinimizedViewWithEditorsBug292966() throws Throwable {
//		testBringToTop_MinimizedViewBug292966(false);
//	}
//
//	public void testBringToTop_MinimizedViewWithoutEditorsBug292966() throws Throwable {
//		testBringToTop_MinimizedViewBug292966(true);
//	}
//
//	public void testGetWorkbenchWindow() {
//		/*
//		 * Commented out because until test case can be updated to work with new
//		 * window/page/perspective implementation
//		 *
//		 * assertEquals(fActivePage.getWorkbenchWindow(), fWin); IWorkbenchPage
//		 * page = openTestPage(fWin); assertEquals(page.getWorkbenchWindow(),
//		 * fWin);
//		 */
//	}
//
//	public void testShowView() throws Throwable {
//		/*
//		 * javadoc: Shows a view in this page and give it focus
//		 */
//		MockViewPart view = (MockViewPart) fActivePage
//				.showView(MockViewPart.ID);
//		assertNotNull(view);
//		assertTrue(view.getCallHistory().verifyOrder(
//				new String[] { "init", "createPartControl", "setFocus" }));
//
//		fActivePage.showView(MockViewPart.ID2);
//
//		/*
//		 * javadoc: If the view is already visible, it is given focus
//		 */
//		CallHistory callTrace = view.getCallHistory();
//		callTrace.clear();
//		assertEquals(fActivePage.showView(MockViewPart.ID), view);
//		assertEquals(callTrace.contains("setFocus"), true);
//	}
//
//	/**
//	 * Tests showing multi-instance views (docked normally).
//	 */
//	public void testShowViewMult() throws Throwable {
//		/*
//		 * javadoc: Shows the view identified by the given view id and secondary
//		 * id in this page and gives it focus. This allows multiple instances of
//		 * a particular view to be created. They are disambiguated using the
//		 * secondary id.
//		 */
//		MockViewPart view = (MockViewPart) fActivePage
//				.showView(MockViewPart.IDMULT);
//		assertNotNull(view);
//		assertTrue(view.getCallHistory().verifyOrder(
//				new String[] { "init", "createPartControl", "setFocus" }));
//		MockViewPart view2 = (MockViewPart) fActivePage.showView(
//				MockViewPart.IDMULT, "2", IWorkbenchPage.VIEW_ACTIVATE);
//		assertNotNull(view2);
//		assertTrue(view2.getCallHistory().verifyOrder(
//				new String[] { "init", "createPartControl", "setFocus" }));
//		assertTrue(!view.equals(view2));
//		MockViewPart view3 = (MockViewPart) fActivePage.showView(
//				MockViewPart.IDMULT, "3", IWorkbenchPage.VIEW_ACTIVATE);
//		assertNotNull(view3);
//		assertTrue(view3.getCallHistory().verifyOrder(
//				new String[] { "init", "createPartControl", "setFocus" }));
//		assertTrue(!view.equals(view3));
//		assertTrue(!view2.equals(view3));
//
//		/*
//		 * javadoc: If there is a view identified by the given view id and
//		 * secondary id already open in this page, it is given focus.
//		 */
//		CallHistory callTrace = view.getCallHistory();
//		callTrace.clear();
//		assertEquals(fActivePage.showView(MockViewPart.IDMULT), view);
//		assertEquals(callTrace.contains("setFocus"), true);
//		CallHistory callTrace2 = view2.getCallHistory();
//		callTrace.clear();
//		callTrace2.clear();
//		assertEquals(fActivePage.showView(MockViewPart.IDMULT, "2",
//				IWorkbenchPage.VIEW_ACTIVATE), view2);
//		assertEquals(callTrace2.contains("setFocus"), true);
//		assertEquals(callTrace.contains("setFocus"), false);
//		CallHistory callTrace3 = view3.getCallHistory();
//		callTrace.clear();
//		callTrace2.clear();
//		callTrace3.clear();
//		assertEquals(fActivePage.showView(MockViewPart.IDMULT, "3",
//				IWorkbenchPage.VIEW_ACTIVATE), view3);
//		assertEquals(callTrace3.contains("setFocus"), true);
//		assertEquals(callTrace.contains("setFocus"), false);
//		assertEquals(callTrace2.contains("setFocus"), false);
//
//		/*
//		 * javadoc: If a secondary id is given, the view must allow multiple
//		 * instances by having specified allowMultiple="true" in its extension.
//		 */
//		boolean exceptionThrown = false;
//		try {
//			fActivePage.showView(MockViewPart.ID, "2",
//					IWorkbenchPage.VIEW_ACTIVATE);
//		} catch (PartInitException e) {
//			assertEquals(e.getMessage().indexOf("mult") != -1, true);
//			exceptionThrown = true;
//		}
//		assertEquals(exceptionThrown, true);
//	}
//
//	/**
//	 * Tests showing multi-instance views (as fast views). This is a regression
//	 * test for bug 76669 - [Perspectives] NullPointerException in
//	 * Perspective.getFastViewWidthRatio()
//	 */
//	public void testShowViewMultFast() throws Throwable {
//		/*
//		 * javadoc: Shows the view identified by the given view id and secondary
//		 * id in this page and gives it focus. This allows multiple instances of
//		 * a particular view to be created. They are disambiguated using the
//		 * secondary id.
//		 */
//		MockViewPart view = (MockViewPart) fActivePage
//				.showView(MockViewPart.IDMULT);
//		assertNotNull(view);
//		assertTrue(view.getCallHistory().verifyOrder(
//				new String[] { "init", "createPartControl", "setFocus" }));
//		MockViewPart view2 = (MockViewPart) fActivePage.showView(
//				MockViewPart.IDMULT, "2", IWorkbenchPage.VIEW_ACTIVATE);
//		assertNotNull(view2);
//		assertTrue(view2.getCallHistory().verifyOrder(
//				new String[] { "init", "createPartControl", "setFocus" }));
//		assertTrue(!view.equals(view2));
//
//		IViewReference ref = (IViewReference) fActivePage.getReference(view);
//		IViewReference ref2 = (IViewReference) fActivePage.getReference(view2);
//		facade.addFastView(fActivePage, ref);
//		facade.addFastView(fActivePage, ref2);
//
//		fActivePage.activate(view);
//		assertEquals(view, fActivePage.getActivePart());
//
//		fActivePage.activate(view2);
//		assertEquals(view2, fActivePage.getActivePart());
//	}
//
//	/**
//	 * Tests saving the page state when there is a fast view that is also a
//	 * multi-instance view. This is a regression test for bug 76669 -
//	 * [Perspectives] NullPointerException in
//	 * Perspective.getFastViewWidthRatio()
//	 */
//	public void testBug76669() throws Throwable {
//		MockViewPart view = (MockViewPart) fActivePage
//				.showView(MockViewPart.IDMULT);
//		MockViewPart view2 = (MockViewPart) fActivePage.showView(
//				MockViewPart.IDMULT, "2", IWorkbenchPage.VIEW_ACTIVATE);
//
//		IViewReference ref = (IViewReference) fActivePage.getReference(view);
//		IViewReference ref2 = (IViewReference) fActivePage.getReference(view2);
//		facade.addFastView(fActivePage, ref);
//		facade.addFastView(fActivePage, ref2);
//
//		IMemento memento = XMLMemento.createWriteRoot("page");
//		facade.saveState(fActivePage, memento);
//		IMemento persps = memento.getChild("perspectives");
//		IMemento persp = persps.getChildren("perspective")[0];
//		IMemento[] fastViews = persp.getChild("fastViews").getChildren("view");
//		assertEquals(2, fastViews.length);
//	}
//
//	public void testFindView() throws Throwable {
//		String id = MockViewPart.ID3;
//		// id of valid, but not open view
//		assertNull(fActivePage.findView(id));
//
//		IViewPart view = fActivePage.showView(id);
//		assertEquals(fActivePage.findView(id), view);
//
//		// close view
//		fActivePage.hideView(view);
//		assertNull(fActivePage.findView(id));
//	}
//
//	public void testFindViewReference() throws Throwable {
//		fActivePage.getWorkbenchWindow().getWorkbench().showPerspective(
//				SessionPerspective.ID, fActivePage.getWorkbenchWindow());
//		assertNull(fActivePage.findViewReference(MockViewPart.ID4));
//
//		fActivePage.showView(MockViewPart.ID4);
//		assertNotNull(fActivePage.findViewReference(MockViewPart.ID4));
//	}
//
//	public void testGetViews() throws Throwable {
//		int totalBefore = fActivePage.getViewReferences().length;
//
//		IViewPart view = fActivePage.showView(MockViewPart.ID2);
//		assertEquals(hasView(view), true);
//		assertEquals(fActivePage.getViewReferences().length, totalBefore + 1);
//
//		fActivePage.hideView(view);
//		assertEquals(hasView(view), false);
//		assertEquals(fActivePage.getViewReferences().length, totalBefore);
//	}
//
//	public void testHideViewWithPart() throws Throwable {
//		// test that nothing bad happens with a null parameter
//		try {
//			fActivePage.hideView((IViewPart) null);
//		} catch (RuntimeException e) {
//			fail(e.getMessage());
//		}
//
//		IViewPart view = fActivePage.showView(MockViewPart.ID3);
//
//		fActivePage.hideView(view);
//		CallHistory callTrace = ((MockViewPart) view).getCallHistory();
//		assertTrue(callTrace.contains("dispose"));
//	}
//
//	public void testHideViewWithReference() throws Throwable {
//		// test that nothing bad happens with a null parameter
//		try {
//			fActivePage.hideView((IViewReference) null);
//		} catch (RuntimeException e) {
//			fail(e.getMessage());
//		}
//
//		IViewPart view = fActivePage.showView(MockViewPart.ID4);
//		IViewReference ref = fActivePage.findViewReference(MockViewPart.ID4);
//		fActivePage.hideView(ref);
//		CallHistory callTrace = ((MockViewPart) view).getCallHistory();
//		assertTrue(callTrace.contains("dispose"));
//
//	}
//
//	public void testHideSaveableView() throws Throwable {
//		String viewId = SaveableMockViewPart.ID;
//		SaveableMockViewPart view = (SaveableMockViewPart) fActivePage
//				.showView(viewId);
//		fActivePage.hideView(view);
//		CallHistory callTrace = view.getCallHistory();
//		assertTrue(callTrace.contains("isDirty"));
//		assertTrue(callTrace.contains("dispose"));
//		assertEquals(fActivePage.findView(viewId), null);
//
//		try {
//			facade.saveableHelperSetAutomatedResponse(1); // No
//			view = (SaveableMockViewPart) fActivePage.showView(viewId);
//			view.setDirty(true);
//			fActivePage.hideView(view);
//			callTrace = view.getCallHistory();
//			assertTrue(callTrace.contains("isDirty"));
//			assertFalse(callTrace.contains("doSave"));
//			assertTrue(callTrace.contains("dispose"));
//			assertEquals(fActivePage.findView(viewId), null);
//
//			facade.saveableHelperSetAutomatedResponse(2); // Cancel
//			view = (SaveableMockViewPart) fActivePage.showView(viewId);
//			view.setDirty(true);
//			fActivePage.hideView(view);
//			callTrace = view.getCallHistory();
//			assertTrue(callTrace.contains("isDirty"));
//			assertFalse(callTrace.contains("doSave"));
//			assertFalse(callTrace.contains("dispose"));
//			assertEquals(fActivePage.findView(viewId), view);
//
//			facade.saveableHelperSetAutomatedResponse(0); // Yes
//			view = (SaveableMockViewPart) fActivePage.showView(viewId);
//			view.setDirty(true);
//			fActivePage.hideView(view);
//			callTrace = view.getCallHistory();
//			assertTrue(callTrace.contains("isDirty"));
//			assertTrue(callTrace.contains("doSave"));
//			assertTrue(callTrace.contains("dispose"));
//			assertEquals(fActivePage.findView(viewId), null);
//
//			// don't leave the view showing, or the UI will block on window
//			// close
//		} finally {
//			facade.saveableHelperSetAutomatedResponse(-1); // restore default
//			// (prompt)
//		}
//	}
//
//	/**
//	 * Tests that a close will fall back to the default if the view returns
//	 * ISaveable2.DEFAULT.
//	 *
//	 * @throws Throwable
//	 */
//	public void testCloseWithSaveNeeded() throws Throwable {
//		String viewId = UserSaveableMockViewPart.ID;
//		UserSaveableMockViewPart view = (UserSaveableMockViewPart) fActivePage
//				.showView(viewId);
//		fActivePage.hideView(view);
//
//		UserSaveableMockViewPart view2 = null;
//
//		CallHistory callTrace = view.getCallHistory();
//		assertTrue(callTrace.contains("isDirty"));
//		assertTrue(callTrace.contains("dispose"));
//		assertEquals(fActivePage.findView(UserSaveableMockViewPart.ID), null);
//
//		try {
//			facade.saveableHelperSetAutomatedResponse(3); // DEFAULT
//			view = (UserSaveableMockViewPart) fActivePage.showView(viewId);
//			view.setDirty(true);
//			view2 = (UserSaveableMockViewPart) fActivePage.showView(viewId,
//					"2", IWorkbenchPage.VIEW_ACTIVATE);
//			assertNotNull(view2);
//			view2.setDirty(true);
//
//			fActivePage.saveAllEditors(true);
//
//			assertFalse(view.isDirty());
//			assertFalse(view2.isDirty());
//
//			callTrace = view.getCallHistory();
//			fActivePage.hideView(view);
//			fActivePage.hideView(view2);
//
//			assertTrue(callTrace.contains("isDirty"));
//			assertTrue(callTrace.contains("doSave"));
//			assertEquals(fActivePage.findView(viewId), null);
//
//			// don't leave the view showing, or the UI will block on window
//			// close
//		} finally {
//			facade
//					.saveableHelperSetAutomatedResponse(-1); // restore
//			// default
//			// (prompt)
//		}
//	}
//
//	/**
//	 * Tests that a close will fall back to the default if the view returns
//	 * ISaveable2.DEFAULT.
//	 *
//	 * @throws Throwable
//	 */
//	public void testSaveEffectsSharedModel() throws Throwable {
//		String viewId = UserSaveableSharedViewPart.ID;
//		UserSaveableSharedViewPart view = null;
//
//		UserSaveableSharedViewPart view2 = null;
//
//		assertEquals(fActivePage.findView(UserSaveableSharedViewPart.ID), null);
//
//		try {
//			facade.saveableHelperSetAutomatedResponse(3); // DEFAULT
//			UserSaveableSharedViewPart.SharedModel model = new UserSaveableSharedViewPart.SharedModel();
//			view = (UserSaveableSharedViewPart) fActivePage.showView(viewId);
//			view.setSharedModel(model);
//
//			view2 = (UserSaveableSharedViewPart) fActivePage.showView(viewId,
//					"2", IWorkbenchPage.VIEW_ACTIVATE);
//			assertNotNull(view2);
//			view2.setSharedModel(model);
//
//			fActivePage.saveAllEditors(true);
//
//			assertFalse(view.isDirty());
//			assertFalse(view2.isDirty());
//
//			CallHistory callTrace = view.getCallHistory();
//			CallHistory call2 = view2.getCallHistory();
//
//			assertTrue(callTrace.contains("isDirty"));
//			assertTrue(call2.contains("isDirty"));
//			assertTrue("At least one should call doSave", callTrace
//					.contains("doSave")
//					|| call2.contains("doSave"));
//			assertFalse("Both should not call doSave", callTrace
//					.contains("doSave")
//					&& call2.contains("doSave"));
//
//			// don't leave the view showing, or the UI will block on window
//			// close
//		} finally {
//			facade
//					.saveableHelperSetAutomatedResponse(-1); // restore
//			// default
//			// (prompt)
//			fActivePage.hideView(view);
//			fActivePage.hideView(view2);
//		}
//	}
//
//	public void testClose() throws Throwable {
//		IWorkbenchPage page = openTestPage(fWin);
//
//		proj = FileUtil.createProject("testOpenEditor");
//		final IFile file = FileUtil.createFile("aaa.mock1", proj);
//		IEditorPart editor = IDE.openEditor(page, file);
//		CallHistory callTrace = ((MockEditorPart) editor).getCallHistory();
//		callTrace.clear();
//
//		/*
//		 * javadoc: If the page has open editors with unsaved content and save
//		 * is true, the user will be given the opportunity to save them
//		 */
//		assertEquals(page.close(), true);
//		assertEquals(callTrace
//				.verifyOrder(new String[] { "isDirty", "dispose" }), true);
//		assertEquals(fWin.getActivePage(), fActivePage);
//	}
//
//	public void testCloseEditor() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		final IFile file = FileUtil.createFile("test.mock1", proj);
//		IEditorPart editor;
//		CallHistory callTrace;
//		MockEditorPart mock;
//
//		/*
//		 * javadoc: Parameters: save - true to save the editor contents if
//		 * required (recommended)
//		 */
//		// create a clean editor that needs to be saved on closing
//		editor = IDE.openEditor(fActivePage, file);
//		mock = (MockEditorPart) editor;
//		mock.setSaveNeeded(true);
//		callTrace = mock.getCallHistory();
//		callTrace.clear();
//		// close the editor with save confirmation
//		assertEquals(fActivePage.closeEditor(editor, true), true);
//		assertEquals(callTrace
//				.verifyOrder(new String[] { "isDirty", "dispose" }), true);
//
//		/*
//		 * javadoc: If the editor has unsaved content and save is true, the user
//		 * will be given the opportunity to save it.
//		 */
//		// can't be tested
//		/*
//		 * javadoc: Parameters: save - false to discard any unsaved changes
//		 */
//		// create a dirty editor
//		editor = IDE.openEditor(fActivePage, file);
//		mock = (MockEditorPart) editor;
//		mock.setDirty(true);
//		mock.setSaveNeeded(true);
//		callTrace = mock.getCallHistory();
//		callTrace.clear();
//		// close the editor and discard changes
//		assertEquals(fActivePage.closeEditor(editor, false), true);
//		assertEquals(callTrace.contains("isSaveOnCloseNeeded"), false);
//		/*
//		 * It is possible that some action may query the isDirty value of the
//		 * editor to update its enabled state. There is nothing wrong in doing
//		 * that, so do not test for no isDirty call here.
//		 *
//		 * assertEquals(callTrace.contains( "isDirty"), false);
//		 */
//		assertEquals(callTrace.contains("doSave"), false);
//		assertEquals(callTrace.contains("dispose"), true);
//	}
//
//	public void testCloseEditors() throws Throwable {
//		int total = 5;
//		final IFile[] files = new IFile[total];
//		IEditorPart[] editors = new IEditorPart[total];
//		IEditorReference[] editorRefs = new IEditorReference[total];
//		CallHistory[] callTraces = new CallHistory[total];
//		MockEditorPart[] mocks = new MockEditorPart[total];
//
//		proj = FileUtil.createProject("testCloseEditors");
//		for (int i = 0; i < total; i++)
//			files[i] = FileUtil.createFile(i + ".mock2", proj);
//
//		/*
//		 * javadoc: If the page has open editors with unsaved content and save
//		 * is true, the user will be given the opportunity to save them.
//		 */
//		// close all clean editors with confirmation
//		for (int i = 0; i < total; i++) {
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			callTraces[i] = ((MockEditorPart) editors[i]).getCallHistory();
//		}
//
//		editorRefs = fActivePage.getEditorReferences();
//		assertEquals(fActivePage.closeEditors(editorRefs, true), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// close all dirty editors with confirmation
//		// can't be tested
//
//		// close all dirty editors discarding them
//		for (int i = 0; i < total; i++) {
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			mocks[i] = (MockEditorPart) editors[i];
//			mocks[i].setDirty(true);
//			callTraces[i] = mocks[i].getCallHistory();
//		}
//		editorRefs = fActivePage.getEditorReferences();
//		assertEquals(fActivePage.closeEditors(editorRefs, false), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("doSave"), false);
//		}
//
//		// close empty array of editors
//		total = 1;
//		for (int i = 0; i < total; i++) {
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			mocks[i] = (MockEditorPart) editors[i];
//			mocks[i].setDirty(true);
//			callTraces[i] = mocks[i].getCallHistory();
//		}
//		// empty array test
//		editorRefs = new IEditorReference[0];
//		assertEquals(fActivePage.closeEditors(editorRefs, true), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// close the last remaining editor, with save=false
//		editorRefs = fActivePage.getEditorReferences();
//		fActivePage.closeEditors(editorRefs, false);
//	}
//
//	public void testCloseAllEditors() throws Throwable {
//		int total = 5;
//		final IFile[] files = new IFile[total];
//		IEditorPart[] editors = new IEditorPart[total];
//		CallHistory[] callTraces = new CallHistory[total];
//		MockEditorPart[] mocks = new MockEditorPart[total];
//
//		proj = FileUtil.createProject("testOpenEditor");
//		for (int i = 0; i < total; i++)
//			files[i] = FileUtil.createFile(i + ".mock2", proj);
//
//		/*
//		 * javadoc: If the page has open editors with unsaved content and save
//		 * is true, the user will be given the opportunity to save them.
//		 */
//		// close all clean editors with confirmation
//		for (int i = 0; i < total; i++) {
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			callTraces[i] = ((MockEditorPart) editors[i]).getCallHistory();
//		}
//		assertEquals(fActivePage.closeAllEditors(true), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// close all dirty editors with confirmation
//		// can't be tested
//
//		// close all dirty editors discarding them
//		for (int i = 0; i < total; i++) {
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			mocks[i] = (MockEditorPart) editors[i];
//			mocks[i].setDirty(true);
//			callTraces[i] = mocks[i].getCallHistory();
//		}
//		assertEquals(fActivePage.closeAllEditors(false), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("doSave"), false);
//		}
//	}
//
//	public void testSaveEditor() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		final IFile file = FileUtil.createFile("test.mock1", proj);
//		IEditorPart editor;
//		CallHistory callTrace;
//		MockEditorPart mock;
//
//		// create a clean editor
//		editor = IDE.openEditor(fActivePage, file);
//		mock = (MockEditorPart) editor;
//		callTrace = mock.getCallHistory();
//		callTrace.clear();
//
//		/*
//		 * javadoc: Saves the contents of the given editor if dirty. If not,
//		 * this method returns without effect
//		 */
//		// save the clean editor with confirmation
//		assertEquals(fActivePage.saveEditor(editor, true), true);
//		assertEquals(callTrace.contains("isDirty"), true);
//		assertEquals(callTrace.contains("doSave"), false);
//
//		/*
//		 * javadoc: If confirm is true the user is prompted to confirm the
//		 * command.
//		 */
//		// can't be tested
//		/*
//		 * javadoc: Otherwise, the save happens without prompt.
//		 */
//		// save the clean editor without confirmation
//		assertEquals(fActivePage.saveEditor(editor, false), true);
//		assertEquals(callTrace.contains("isDirty"), true);
//		assertEquals(callTrace.contains("doSave"), false);
//
//		// save the dirty editor without confirmation
//		mock.setDirty(true);
//		callTrace.clear();
//		assertEquals(fActivePage.saveEditor(editor, false), true);
//		assertEquals(callTrace
//				.verifyOrder(new String[] { "isDirty", "doSave" }), true);
//	}
//
//	public void testIDESaveAllEditors() throws Throwable {
//		int total = 3;
//
//		final IFile[] files = new IFile[total];
//		IEditorPart[] editors = new IEditorPart[total];
//		CallHistory[] callTraces = new CallHistory[total];
//		MockEditorPart[] mocks = new MockEditorPart[total];
//
//		proj = FileUtil.createProject("testOpenEditor");
//		for (int i = 0; i < total; i++) {
//			files[i] = FileUtil.createFile(i + ".mock2", proj);
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			mocks[i] = (MockEditorPart) editors[i];
//			callTraces[i] = mocks[i].getCallHistory();
//		}
//
//		/*
//		 * javadoc: If there are no dirty editors this method returns without
//		 * effect. javadoc: If confirm is true the user is prompted to confirm
//		 * the command
//		 */
//		// save all clean editors with confirmation
//		assertEquals(IDE.saveAllEditors(new IResource[] { proj }, true), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// save all dirty editors with confirmation can't be tested
//
//		/*
//		 * javadoc: Parameters: confirm - false to save unsaved changes without
//		 * asking
//		 */
//		// save all clean editors without confirmation
//		assertEquals(IDE.saveAllEditors(new IResource[] { proj }, false), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// save all dirty editors with resource that IS NOT a parent
//		// of the contents of the dirty editors without confirmation, this
//		// should not
//		// save any as they are not parented by the resource provided
//		for (int i = 0; i < total; i++)
//			mocks[i].setDirty(true);
//
//		IResource emptyProj = FileUtil
//				.createProject("testOpenEditorEmptyProject");
//		assertEquals(IDE.saveAllEditors(new IResource[] { emptyProj }, false),
//				true);
//		for (int i = 0; i < total; i++) {
//			// the editors were not in the empty project hence still dirty
//			assertEquals(mocks[i].isDirty(), true);
//			callTraces[i].clear();
//		}
//
//		// save all dirty editors with resource that IS a parent
//		// of the contents of the editors without confirmation, this should
//		// save them as they are parented by the resource provided
//		assertEquals(IDE.saveAllEditors(new IResource[] { proj }, false), true);
//		for (int i = 0; i < total; i++) {
//			// the editors were not in the empty project hence still dirty
//			assertEquals(mocks[i].isDirty(), false);
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), true);
//			callTraces[i].clear();
//		}
//
//		// save all dirty editors with resource that IS NOT a parent
//		// of the contents of the dirty editors without confirmation, this
//		// should not
//		// save any as they are not parented by the resource provided
//		for (int i = 0; i < total; i++)
//			mocks[i].setDirty(true);
//		assertEquals(IDE.saveAllEditors(new IResource[] {}, false), true);
//		for (int i = 0; i < total; i++) {
//			// the editors were not in the empty project hence still dirty
//			assertEquals(mocks[i].isDirty(), true);
//			callTraces[i].clear();
//		}
//
//		// clear the dirty state so the tearDown does not open a confirm dialog.
//		for (int i = 0; i < total; i++)
//			mocks[i].setDirty(false);
//	}
//
//	public void testSaveAllEditors() throws Throwable {
//		int total = 3;
//
//		final IFile[] files = new IFile[total];
//		IEditorPart[] editors = new IEditorPart[total];
//		CallHistory[] callTraces = new CallHistory[total];
//		MockEditorPart[] mocks = new MockEditorPart[total];
//
//		proj = FileUtil.createProject("testOpenEditor");
//		for (int i = 0; i < total; i++) {
//			files[i] = FileUtil.createFile(i + ".mock2", proj);
//			editors[i] = IDE.openEditor(fActivePage, files[i]);
//			mocks[i] = (MockEditorPart) editors[i];
//			callTraces[i] = mocks[i].getCallHistory();
//		}
//
//		/*
//		 * javadoc: If there are no dirty editors this method returns without
//		 * effect. javadoc: If confirm is true the user is prompted to confirm
//		 * the command
//		 */
//		// save all clean editors with confirmation
//		assertEquals(fActivePage.saveAllEditors(true), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// save all dirty editors with confirmation can't be tested
//
//		/*
//		 * javadoc: Parameters: confirm - false to save unsaved changes without
//		 * asking
//		 */
//		// save all clean editors without confirmation
//		assertEquals(fActivePage.saveAllEditors(false), true);
//		for (int i = 0; i < total; i++) {
//			assertEquals(callTraces[i].contains("isDirty"), true);
//			assertEquals(callTraces[i].contains("doSave"), false);
//			callTraces[i].clear();
//		}
//
//		// save all dirty editors without confirmation
//		for (int i = 0; i < total; i++)
//			mocks[i].setDirty(true);
//		assertEquals(fActivePage.saveAllEditors(false), true);
//		for (int i = 0; i < total; i++)
//			assertEquals(callTraces[i].verifyOrder(new String[] { "isDirty",
//					"doSave" }), true);
//	}
//
//	public void testGetEditors() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditor");
//		int totalBefore = fActivePage.getEditorReferences().length;
//		int num = 3;
//		IEditorPart[] editors = new IEditorPart[num];
//
//		for (int i = 0; i < num; i++) {
//			editors[i] = IDE.openEditor(fActivePage, FileUtil.createFile(i
//					+ ".mock2", proj));
//			assertEquals(hasEditor(editors[i]), true);
//		}
//		assertEquals(fActivePage.getEditorReferences().length, totalBefore
//				+ num);
//
//		fActivePage.closeEditor(editors[0], false);
//		assertEquals(hasEditor(editors[0]), false);
//		assertEquals(fActivePage.getEditorReferences().length, totalBefore
//				+ num - 1);
//
//		fActivePage.closeAllEditors(false);
//		assertEquals(fActivePage.getEditorReferences().length, 0);
//	}
//
//	public void testShowActionSet() {
//		String id = MockActionDelegate.ACTION_SET_ID;
//
//		int totalBefore = facade.getActionSetCount(fActivePage);
//		fActivePage.showActionSet(id);
//
//		facade.assertActionSetId(fActivePage, id, true);
//
//		// check that the method does not add an invalid action set to itself
//		id = IConstants.FakeID;
//		fActivePage.showActionSet(id);
//
//		facade.assertActionSetId(fActivePage, id, false);
//		assertEquals(facade.getActionSetCount(fActivePage), totalBefore + 1);
//	}
//
//	public void testHideActionSet() {
//		int totalBefore = facade.getActionSetCount(fActivePage);
//
//		String id = MockWorkbenchWindowActionDelegate.SET_ID;
//		fActivePage.showActionSet(id);
//		assertEquals(facade.getActionSetCount(fActivePage), totalBefore + 1);
//
//		fActivePage.hideActionSet(id);
//		assertEquals(facade.getActionSetCount(fActivePage), totalBefore);
//
//		facade.assertActionSetId(fActivePage, id, false);
//	}
//
//	/**
//	 * Return whether or not the editor exists in the current page.
//	 *
//	 * @param editor
//	 * @return boolean
//	 */
//	private boolean hasEditor(IEditorPart editor) {
//		IEditorReference[] references = fActivePage.getEditorReferences();
//		for (int i = 0; i < references.length; i++) {
//			if (references[i].getEditor(false).equals(editor))
//				return true;
//		}
//		return false;
//	}
//
//	/**
//	 * Return whether or not the view exists in the current page.
//	 *
//	 * @param editor
//	 * @return boolean
//	 */
//	private boolean hasView(IViewPart view) {
//		IViewReference[] references = fActivePage.getViewReferences();
//		for (int i = 0; i < references.length; i++) {
//			if (references[i].getView(false).equals(view))
//				return true;
//		}
//		return false;
//	}
//
//	public void testStackOrder() throws PartInitException {
//		IViewPart part1 = fActivePage.showView(MockViewPart.ID);
//		IViewPart part2 = fActivePage.showView(MockViewPart.ID2);
//		IViewPart part3 = fActivePage.showView(MockViewPart.ID3);
//		IViewPart part4 = fActivePage.showView(MockViewPart.ID4);
//
//		IViewPart[] stack = fActivePage.getViewStack(part1);
//		assertTrue(stack.length == 4);
//		assertTrue(stack[0] == part4);
//		assertTrue(stack[1] == part3);
//		assertTrue(stack[2] == part2);
//		assertTrue(stack[3] == part1);
//
//		fActivePage.activate(part2);
//		stack = fActivePage.getViewStack(part1);
//		assertTrue(stack.length == 4);
//		assertTrue(stack[0] == part2);
//		assertTrue(stack[1] == part4);
//		assertTrue(stack[2] == part3);
//		assertTrue(stack[3] == part1);
//
//		fActivePage.activate(part1);
//		stack = fActivePage.getViewStack(part1);
//		assertTrue(stack.length == 4);
//		assertTrue(stack[0] == part1);
//		assertTrue(stack[1] == part2);
//		assertTrue(stack[2] == part4);
//		assertTrue(stack[3] == part3);
//
//		fActivePage.activate(part3);
//		stack = fActivePage.getViewStack(part1);
//		assertTrue(stack.length == 4);
//		assertTrue(stack[0] == part3);
//		assertTrue(stack[1] == part1);
//		assertTrue(stack[2] == part2);
//		assertTrue(stack[3] == part4);
//	}
//
//	/**
//	 * Test the VIEW_CREATE parameter for showView. Ensures that the created
//	 * view is not the active part.
//	 *
//	 */
//	public void testView_CREATE1() throws PartInitException {
//		fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//							"org.eclipse.ui.tests.api.ViewPerspective"));
//
//		// create a part to be active
//		IViewPart activePart = fActivePage.showView(MockViewPart.ID);
//		IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
//				IWorkbenchPage.VIEW_CREATE);
//
//		IViewPart[] stack = fActivePage.getViewStack(activePart);
//		assertEquals(2, stack.length);
//
//		assertEquals(activePart, stack[0]);
//		assertEquals(createdPart, stack[1]);
//
//		assertFalse(fActivePage.isPartVisible(createdPart));
//
//		assertEquals(activePart, fActivePage.getActivePart());
//	}
//
//	/**
//	 * Test the VIEW_CREATE parameter for showView. Ensures that the created
//	 * view is not the active part and is not visible
//	 */
//	public void testView_CREATE2() throws PartInitException {
//		fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//						"org.eclipse.ui.tests.api.ViewPerspective"));
//
//		// create a part to be active
//		IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
//		IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
//				IWorkbenchPage.VIEW_CREATE);
//
//		IViewPart[] stack = fActivePage.getViewStack(createdPart);
//		assertEquals(2, stack.length);
//
//		assertEquals(fActivePage.findView(MockViewPart.ID), stack[0]);
//		assertEquals(createdPart, stack[1]);
//
//		assertFalse(fActivePage.isPartVisible(createdPart));
//
//		assertEquals(activePart, fActivePage.getActivePart());
//	}
//
//	/**
//	 * Test the VIEW_CREATE parameter for showView. Ensures that the created
//	 * view is not the active part and is visible.
//	 */
//	public void testView_CREATE3() throws PartInitException {
//		fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//						"org.eclipse.ui.tests.api.ViewPerspective"));
//
//		// create a part to be active
//		IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
//		IViewPart createdPart = fActivePage.showView(MockViewPart.ID4, null,
//				IWorkbenchPage.VIEW_CREATE);
//
//		IViewPart[] stack = fActivePage.getViewStack(createdPart);
//		assertEquals(1, stack.length);
//
//		assertEquals(createdPart, stack[0]);
//
//		assertTrue(fActivePage.isPartVisible(createdPart));
//
//		assertEquals(activePart, fActivePage.getActivePart());
//	}
//
//	/**
//	 * Test the VIEW_VISIBLE parameter for showView, opening the view in the
//	 * stack containing the active view. Ensures that the created view is not
//	 * the active part and is not visible.
//	 */
//	public void testView_VISIBLE1() throws PartInitException {
//		fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//						"org.eclipse.ui.tests.api.ViewPerspective"));
//
//		// create a part to be active
//		IViewPart activePart = fActivePage.showView(MockViewPart.ID);
//		IViewPart createdPart = fActivePage.showView(MockViewPart.ID2, null,
//				IWorkbenchPage.VIEW_VISIBLE);
//		IViewPart[] stack = fActivePage.getViewStack(activePart);
//		assertEquals(2, stack.length);
//
//		assertEquals(activePart, stack[0]);
//		assertEquals(createdPart, stack[1]);
//
//		assertFalse(fActivePage.isPartVisible(createdPart));
//
//		assertEquals(activePart, fActivePage.getActivePart());
//	}
//
//	/**
//	 * Test the VIEW_VISIBLE parameter for showView, opening the view in its own
//	 * stack. Ensures that the created view is not active part but is the top
//	 * part in its stack.
//	 */
//	public void testView_VISIBLE3() throws PartInitException {
//		fActivePage.setPerspective(fActivePage.getWorkbenchWindow().getWorkbench()
//					.getPerspectiveRegistry().findPerspectiveWithId(
//							"org.eclipse.ui.tests.api.ViewPerspective"));
//
//		// create a part to be active
//		IViewPart activePart = fActivePage.showView(MockViewPart.ID3);
//
//		IViewPart createdPart = fActivePage.showView(MockViewPart.ID4, null,
//				IWorkbenchPage.VIEW_VISIBLE);
//		IViewPart[] stack = fActivePage.getViewStack(createdPart);
//		assertEquals(1, stack.length);
//
//		assertEquals(createdPart, stack[0]);
//
//		assertTrue(fActivePage.isPartVisible(createdPart));
//
//		assertEquals(activePart, fActivePage.getActivePart());
//	}
//
//	/**
//	 * Test opening a perspective with a fast view.
//	 */
//	public void testOpenPerspectiveWithFastView() {
//
//		try {
//			fWin.getWorkbench().showPerspective(
//					PerspectiveWithFastView.PERSP_ID, fWin);
//		} catch (WorkbenchException e) {
//			fail("Unexpected WorkbenchException: " + e);
//		}
//
//		IViewReference[] fastViews = facade.getFastViews(fActivePage);
//		assertEquals(fastViews.length, 1);
//		assertEquals(fastViews[0].getId(),
//				"org.eclipse.ui.views.ResourceNavigator");
//		assertEquals(fActivePage.getViewReferences().length, 1);
//		assertTrue(fActivePage.getViewReferences()[0].isFastView());
//
//		IPerspectiveDescriptor persp = fActivePage.getPerspective();
//
//		ICommandService commandService = (ICommandService) fWorkbench.getService(ICommandService.class);
//		Command command = commandService.getCommand("org.eclipse.ui.window.closePerspective");
//
//		HashMap parameters = new HashMap();
//		parameters.put(IWorkbenchCommandConstants.WINDOW_CLOSE_PERSPECTIVE_PARM_ID, persp.getId());
//
//		ParameterizedCommand pCommand = ParameterizedCommand.generateCommand(command, parameters);
//
//		IHandlerService handlerService = (IHandlerService) fWorkbench
//				.getService(IHandlerService.class);
//		try {
//			handlerService.executeCommand(pCommand, null);
//		} catch (ExecutionException e1) {
//		} catch (NotDefinedException e1) {
//		} catch (NotEnabledException e1) {
//		} catch (NotHandledException e1) {
//		}
//
//	}
//
//	/**
//	 * Test opening a perspective with placeholders for multi instance views.
//	 * The placeholders are added at top level (not in any folder).
//	 *
//	 * @since 3.1
//	 */
//	public void testOpenPerspectiveWithMultiViewPlaceholdersAtTopLevel() {
//
//		try {
//			fWin.getWorkbench().showPerspective(
//					PerspectiveWithMultiViewPlaceholdersAtTopLevel.PERSP_ID,
//					fWin);
//		} catch (WorkbenchException e) {
//			fail("Unexpected WorkbenchException: " + e);
//		}
//
//		ArrayList partIds = facade.getPerspectivePartIds(fActivePage, null);
//		assertTrue(partIds.contains("*"));
//		assertTrue(partIds.contains(MockViewPart.IDMULT));
//		assertTrue(partIds.contains(MockViewPart.IDMULT + ":secondaryId"));
//		assertTrue(partIds.contains(MockViewPart.IDMULT + ":*"));
//	}
//
//	/**
//	 * Test opening a perspective with placeholders for multi instance views.
//	 * The placeholders are added in a placeholder folder. This is a regression
//	 * test for bug 72383 [Perspectives] Placeholder folder error with multiple
//	 * instance views
//	 *
//	 * @since 3.1
//	 */
//	public void testOpenPerspectiveWithMultiViewPlaceholdersInPlaceholderFolder() {
//
//		try {
//			fWin
//					.getWorkbench()
//					.showPerspective(
//							PerspectiveWithMultiViewPlaceholdersInPlaceholderFolder.PERSP_ID,
//							fWin);
//		} catch (WorkbenchException e) {
//			fail("Unexpected WorkbenchException: " + e);
//		}
//
//		ArrayList partIds = facade.getPerspectivePartIds(fActivePage,"placeholderFolder");
//		assertTrue(partIds.contains("*"));
//		assertTrue(partIds.contains(MockViewPart.IDMULT));
//		assertTrue(partIds.contains(MockViewPart.IDMULT + ":secondaryId"));
//		assertTrue(partIds.contains(MockViewPart.IDMULT + ":*"));
//	}
//
//	/**
//	 * Test opening a perspective with placeholders for multi instance views.
//	 * The placeholders are added at top level (not in any folder).
//	 *
//	 * @since 3.1
//	 */
//	public void testOpenPerspectiveWithMultiViewPlaceholdersInFolder() {
//		try {
//			fWin
//					.getWorkbench()
//					.showPerspective(
//							PerspectiveWithMultiViewPlaceholdersInFolder.PERSP_ID,
//							fWin);
//		} catch (WorkbenchException e) {
//			fail("Unexpected WorkbenchException: " + e);
//		}
//
//		ArrayList partIds = facade.getPerspectivePartIds(fActivePage,"folder");
//		assertTrue(partIds.contains("*"));
//		assertTrue(partIds.contains(MockViewPart.IDMULT));
//		assertTrue(partIds.contains(MockViewPart.IDMULT + ":secondaryId"));
//		assertTrue(partIds.contains(MockViewPart.IDMULT + ":*"));
//	}
//
//	/**
//	 * Tests the getNewWizardShortcuts() method.
//	 *
//	 * @since 3.1
//	 */
//	public void testGetNewWizardShortcuts() {
//		String[] shortcuts = fActivePage.getNewWizardShortcuts();
//		assertNotNull(shortcuts);
//		assertEquals(0, shortcuts.length);
//
//		IWorkbenchWindow win = openTestWindow(IDE.RESOURCE_PERSPECTIVE_ID);
//		IWorkbenchPage page = win.getActivePage();
//		shortcuts = page.getNewWizardShortcuts();
//		List shortcutList = Arrays.asList(shortcuts);
//		assertTrue(shortcutList.contains("org.eclipse.ui.wizards.new.folder"));
//		assertTrue(shortcutList.contains("org.eclipse.ui.wizards.new.file"));
//	}
//
//	/**
//	 * Tests the getShowViewShortcuts() method.
//	 *
//	 * @since 3.1
//	 */
//	public void testGetShowViewShortcuts() {
//		String[] shortcuts = fActivePage.getShowViewShortcuts();
//		assertNotNull(shortcuts);
//		assertEquals(0, shortcuts.length);
//
//		IWorkbenchWindow win = openTestWindow(IDE.RESOURCE_PERSPECTIVE_ID);
//		IWorkbenchPage page = win.getActivePage();
//		shortcuts = page.getShowViewShortcuts();
//		List shortcutList = Arrays.asList(shortcuts);
//		assertTrue(shortcutList.contains(ProjectExplorer.VIEW_ID));
//		assertTrue(shortcutList.contains(IPageLayout.ID_OUTLINE));
//		assertTrue(shortcutList.contains(IPageLayout.ID_PROP_SHEET));
//		assertTrue(shortcutList.contains(IPageLayout.ID_PROBLEM_VIEW));
//	}
//
//	/**
//	 * Tests the getPerspectiveShortcuts() method.
//	 *
//	 * @since 3.1
//	 */
//	public void testGetPerspectiveShortcuts() {
//		String[] shortcuts = fActivePage.getPerspectiveShortcuts();
//		assertNotNull(shortcuts);
//		assertEquals(0, shortcuts.length);
//		// not much of a test
//	}
//
//	/**
//	 * Tests the getOpenPerspectives() method.
//	 *
//	 * @since 3.1
//	 */
//	public void testGetOpenPerspectives() {
//		IPerspectiveDescriptor[] openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(1, openPersps.length);
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//
//		IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
//		IPerspectiveDescriptor resourcePersp = reg
//				.findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//		fActivePage.setPerspective(resourcePersp);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(2, openPersps.length);
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//		assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[1].getId());
//
//		IPerspectiveDescriptor emptyPersp = reg
//				.findPerspectiveWithId(EmptyPerspective.PERSP_ID);
//		fActivePage.setPerspective(emptyPersp);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(2, openPersps.length);
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//		assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[1].getId());
//
//		fActivePage.closeAllPerspectives(false, false);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(0, openPersps.length);
//
//		fActivePage.close();
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(0, openPersps.length);
//	}
//
//	/**
//	 * Tests the getSortedPerspectives() method.
//	 *
//	 * @since 3.1
//	 */
//	public void testGetSortedPerspectives() {
//		IPerspectiveDescriptor[] openPersps = fActivePage
//				.getSortedPerspectives();
//		assertEquals(1, openPersps.length);
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//
//		IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
//		IPerspectiveDescriptor resourcePersp = reg
//				.findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//		fActivePage.setPerspective(resourcePersp);
//		openPersps = fActivePage.getSortedPerspectives();
//		assertEquals(2, openPersps.length);
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//		assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[1].getId());
//
//		IPerspectiveDescriptor emptyPersp = reg
//				.findPerspectiveWithId(EmptyPerspective.PERSP_ID);
//		fActivePage.setPerspective(emptyPersp);
//		openPersps = fActivePage.getSortedPerspectives();
//		assertEquals(2, openPersps.length);
//		assertEquals(IDE.RESOURCE_PERSPECTIVE_ID, openPersps[0].getId());
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[1].getId());
//
//		fActivePage.closeAllPerspectives(false, false);
//		openPersps = fActivePage.getSortedPerspectives();
//		assertEquals(0, openPersps.length);
//
//		fActivePage.close();
//		openPersps = fActivePage.getSortedPerspectives();
//		assertEquals(0, openPersps.length);
//	}
//
//	/**
//	 * Tests the closePerspective method.
//	 *
//	 * @since 3.1
//	 */
//	public void testClosePerspective() {
//		// TODO: Need to test variants with saveEditors==true
//
//		IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
//		IPerspectiveDescriptor emptyPersp = reg
//				.findPerspectiveWithId(EmptyPerspective.PERSP_ID);
//		IPerspectiveDescriptor resourcePersp = reg
//				.findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
//		fActivePage.setPerspective(resourcePersp);
//		IPerspectiveDescriptor[] openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(2, openPersps.length);
//
//		fActivePage.closePerspective(resourcePersp, false, false);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(1, openPersps.length);
//		assertEquals(EmptyPerspective.PERSP_ID, openPersps[0].getId());
//
//		fActivePage.closePerspective(emptyPersp, false, false);
//		assertEquals(fActivePage, fWin.getActivePage()); // page not closed
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(0, openPersps.length);
//
//		fActivePage.setPerspective(emptyPersp);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(1, openPersps.length);
//
//		fActivePage.closePerspective(emptyPersp, false, true);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(0, openPersps.length);
//		assertNull(fWin.getActivePage()); // page closed
//	}
//
// 	/**
//	 * This tests that closing a perspective will not bring a prompt up for
//	 * {@link org.eclipse.ui.ISaveablePart ISaveablePart} implementations that
//	 * are returning false for their
//	 * {@link org.eclipse.ui.ISaveablePart#isSaveOnCloseNeeded()
//	 * isSaveOnCloseNeeded()} implementation.
//	 *
//	 * @see #testCloseAllPerspectivesDoesNotPromptBug272070()
//	 */
//	public void testClosePerspectiveDoesNotPromptBug272070() throws Exception {
//		try {
//			facade.saveableHelperSetAutomatedResponse(2);
//			proj = FileUtil
//					.createProject("testClosePerspectiveDoesNotPromptBug272070");
//
//			IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
//			IPerspectiveDescriptor resourcePersp = reg
//					.findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
//			// close all perspectives so we start fresh
//			fActivePage.closeAllPerspectives(false, false);
//			// set the page to the 'Resource' perspective
//			fActivePage.setPerspective(resourcePersp);
//
//			// create a file and show an editor
//			IEditorInput input = new FileEditorInput(FileUtil.createFile(
//					"test.mock1", proj));
//			MockEditorPart editor = (MockEditorPart) fActivePage.openEditor(
//					input, MockEditorPart.ID1);
//
//			// mark the editor as being dirty but not requiring saving when
//			// closed
//			editor.setDirty(true);
//			editor.setSaveNeeded(false);
//
//			// close the perspective
//			fActivePage.closePerspective(resourcePersp, true, false);
//			// mark the editor as not dirty, this is important because if the
//			// editor is not closed, the test will fail and when JUnit tries to
//			// tear down the workbench it will not shutdown because it will
//			// prompt about the editor being dirty
//			editor.setDirty(false);
//			// the editor should have been closed when the perspective was
//			// closed
//			assertFalse("The editor should've been closed", fActivePage
//					.isPartVisible(editor));
//
//			// set the page to the 'Resource' perspective
//			fActivePage.setPerspective(resourcePersp);
//
//			// show a view
//			SaveableMockViewPart view = (SaveableMockViewPart) fActivePage
//					.showView(SaveableMockViewPart.ID);
//
//			// mark the view as being dirty but not requiring saving when closed
//			view.setDirty(true);
//			view.setSaveNeeded(false);
//
//			// close the perspective
//			fActivePage.closePerspective(resourcePersp, true, false);
//			// like the editor above, we need to mark the view as not being
//			// dirty for the same reasons
//			view.setDirty(false);
//			// the view should have been hidden when the perspective was closed
//			assertFalse("The view should be hidden", fActivePage
//					.isPartVisible(view));
//		} finally {
//			facade
//					.saveableHelperSetAutomatedResponse(-1);
//		}
//	}
//
//	/**
//	 * Tests the closeAllPerspectives method.
//	 *
//	 * @since 3.1
//	 */
//	public void testCloseAllPerspectives() {
//		// TODO: Need to test variants with saveEditors==true
//
//		IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
//		IPerspectiveDescriptor emptyPersp = reg
//				.findPerspectiveWithId(EmptyPerspective.PERSP_ID);
//		IPerspectiveDescriptor resourcePersp = reg
//				.findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
//		fActivePage.setPerspective(resourcePersp);
//		IPerspectiveDescriptor[] openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(2, openPersps.length);
//
//		fActivePage.closeAllPerspectives(false, false);
//		assertEquals(fActivePage, fWin.getActivePage()); // page not closed
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(0, openPersps.length);
//
//		fActivePage.setPerspective(emptyPersp);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(1, openPersps.length);
//
//		fActivePage.closeAllPerspectives(false, true);
//		openPersps = fActivePage.getOpenPerspectives();
//		assertEquals(0, openPersps.length);
//		assertNull(fWin.getActivePage()); // page closed
//	}
//
// 	/**
//	 * This tests that closing all perspectives will not bring a prompt up for
//	 * {@link org.eclipse.ui.ISaveablePart ISaveablePart} implementations that
//	 * are returning false for their
//	 * {@link org.eclipse.ui.ISaveablePart#isSaveOnCloseNeeded()
//	 * isSaveOnCloseNeeded()} implementation.
//	 *
//	 * @see #testClosePerspectiveDoesNotPromptBug272070()
//	 */
//	public void testCloseAllPerspectivesDoesNotPromptBug272070()
//			throws Exception {
//		try {
//			facade.saveableHelperSetAutomatedResponse(2);
//			proj = FileUtil
//					.createProject("testCloseAllPerspectivesDoesNotPromptBug272070");
//
//			IPerspectiveRegistry reg = fWorkbench.getPerspectiveRegistry();
//			IPerspectiveDescriptor resourcePersp = reg
//					.findPerspectiveWithId(IDE.RESOURCE_PERSPECTIVE_ID);
//
//			// close all perspectives so we start fresh
//			fActivePage.closeAllPerspectives(false, false);
//			// set the page to the 'Resource' perspective
//			fActivePage.setPerspective(resourcePersp);
//
//			// create a file and show an editor
//			IEditorInput input = new FileEditorInput(FileUtil.createFile(
//					"test.mock1", proj));
//			MockEditorPart editor = (MockEditorPart) fActivePage.openEditor(
//					input, MockEditorPart.ID1);
//
//			// mark the editor as being dirty but not requiring saving when
//			// closed
//			editor.setDirty(true);
//			editor.setSaveNeeded(false);
//
//			// close all perspectives
//			fActivePage.closeAllPerspectives(true, false);
//			// mark the editor as not dirty, this is important because if the
//			// editor is not closed, the test will fail and when JUnit tries to
//			// tear down the workbench it will not shutdown because it will
//			// prompt about the editor being dirty
//			editor.setDirty(false);
//			// the editor should have been closed when the perspective was
//			// closed
//			assertFalse("The editor should've been closed", fActivePage
//					.isPartVisible(editor));
//
//			// set the page to the 'Resource' perspective
//			fActivePage.setPerspective(resourcePersp);
//
//			// show a view
//			SaveableMockViewPart view = (SaveableMockViewPart) fActivePage
//					.showView(SaveableMockViewPart.ID);
//
//			// mark the view as being dirty but not requiring saving when closed
//			view.setDirty(true);
//			view.setSaveNeeded(false);
//
//			// close all perspectives
//			fActivePage.closeAllPerspectives(true, false);
//			// like the editor above, we need to mark the view as not being
//			// dirty for the same reasons
//			view.setDirty(false);
//			// the view should have been hidden when the perspective was closed
//			assertFalse("The view should be hidden", fActivePage
//					.isPartVisible(view));
//		} finally {
//			facade
//					.saveableHelperSetAutomatedResponse(-1);
//		}
//	}
//
//	/**
//	 * Regression test for Bug 76285 [Presentations] Folder tab does not
//	 * indicate current view. Tests that, when switching between perspectives,
//	 * the remembered old part correctly handles multi-view instances.
//	 */
//	public void testBug76285() {
//		IWorkbenchPage page = fActivePage;
//		IPerspectiveDescriptor originalPersp = page.getPerspective();
//		IPerspectiveDescriptor resourcePersp = PlatformUI.getWorkbench()
//				.getPerspectiveRegistry().findPerspectiveWithId(
//						IDE.RESOURCE_PERSPECTIVE_ID);
//		// test requires switching between two different perspectives
//		assertNotSame(originalPersp, resourcePersp);
//
//		int n = 5;
//		IViewPart[] views = new IViewPart[n];
//		for (int i = 0; i < n; ++i) {
//			try {
//				views[i] = page.showView(MockViewPart.IDMULT, Integer
//						.toString(i), IWorkbenchPage.VIEW_CREATE);
//			} catch (PartInitException e) {
//				fail(e.getMessage());
//			}
//		}
//		assertEquals(5, page.getViews().length);
//		for (int i = 0; i < n; ++i) {
//			page.activate(views[i]);
//			page.setPerspective(resourcePersp);
//			assertFalse(page.getActivePart() instanceof MockViewPart);
//			page.setPerspective(originalPersp);
//			assertEquals(views[i], page.getActivePart());
//		}
//	}
//
//	/**
//	 * Tests that IShowEditorInput.showEditorInput is called when a matching
//	 * editor is found during openEditor, and is not called when a new editor is
//	 * opened.
//	 *
//	 * @since 3.1
//	 */
//	public void testShowEditorInput() throws Exception {
//		IWorkbenchPage page = fActivePage;
//		proj = FileUtil.createProject("testShowEditorInput");
//		IFile file = FileUtil.createFile("a.mock1", proj);
//		MockEditorPart part1 = (MockEditorPart) IDE.openEditor(page, file);
//		assertFalse(part1.getCallHistory().contains("showEditorInput"));
//
//		MockEditorPart part2 = (MockEditorPart) IDE.openEditor(page, file);
//		assertTrue(part1 == part2);
//		assertTrue(part2.getCallHistory().contains("showEditorInput"));
//	}
//
//	/**
//	 * Tests that the openEditor and findEditor variants that accepts match
//	 * flags work as expected.
//	 *
//	 * @since 3.2
//	 */
//	public void testOpenAndFindEditorWithMatchFlags() throws Exception {
//		IWorkbenchPage page = fActivePage;
//		proj = FileUtil.createProject("testOpenEditorMatchFlags");
//		IFile file1 = FileUtil.createFile("a.mock1", proj);
//		IFile file2 = FileUtil.createFile("a.mock2", proj);
//		FileEditorInput input1 = new FileEditorInput(file1);
//		FileEditorInput input2 = new FileEditorInput(file2);
//		String id1 = MockEditorPart.ID1;
//		String id2 = MockEditorPart.ID2;
//
//		// first editor (no match)
//		MockEditorPart part1 = (MockEditorPart) page.openEditor(input1, id1,
//				true, IWorkbenchPage.MATCH_INPUT);
//		assertNotNull(part1);
//
//		// same input, same id, matching input (should match part1)
//		MockEditorPart part2 = (MockEditorPart) page.openEditor(input1, id1,
//				true, IWorkbenchPage.MATCH_INPUT);
//		assertTrue(part1 == part2);
//
//		// same input, different id, matching input (should match part1)
//		MockEditorPart part3 = (MockEditorPart) page.openEditor(input1, id2,
//				true, IWorkbenchPage.MATCH_INPUT);
//		assertTrue(part1 == part3);
//
//		// same input, different id, matching input and id (no match)
//		MockEditorPart part4 = (MockEditorPart) page.openEditor(input1, id2,
//				true, IWorkbenchPage.MATCH_INPUT | IWorkbenchPage.MATCH_ID);
//		assertNotNull(part4);
//		assertTrue(part4 != part1);
//
//		// same input, same id, matching nothing (no match)
//		MockEditorPart part5 = (MockEditorPart) page.openEditor(input1, id1,
//				true, IWorkbenchPage.MATCH_NONE);
//		assertNotNull(part5);
//		assertTrue(part5 != part1);
//		assertTrue(part5 != part4);
//
//		// different input, same id, matching id (should match part5 instead of
//		// part1, because it was active)
//		MockEditorPart part6 = (MockEditorPart) page.openEditor(input2, id1,
//				true, IWorkbenchPage.MATCH_ID);
//		assertTrue(part6 == part5);
//
//		// different input, different id, matching input and id (no match)
//		MockEditorPart part7 = (MockEditorPart) page.openEditor(input2, id2,
//				true, IWorkbenchPage.MATCH_INPUT | IWorkbenchPage.MATCH_ID);
//		assertNotNull(part7);
//		assertTrue(part7 != part1);
//		assertTrue(part7 != part4);
//		assertTrue(part7 != part5);
//
//		// At this point, there are 4 editors open:
//		// part1 (input1, id1), part4 (input1, id2), part5 (input1, id1), and
//		// part7 (input2, id2).
//		// with part7 active.
//
//		// find with MATCH_NONE is always empty
//		IEditorReference[] refs = page.findEditors(input1, id1,
//				IWorkbenchPage.MATCH_NONE);
//		assertEquals(0, refs.length);
//
//		// find input1 with MATCH_INPUT finds 3 editors: part1, part4 and part5
//		// (in order)
//		refs = page.findEditors(input1, null, IWorkbenchPage.MATCH_INPUT);
//		assertEquals(3, refs.length);
//		assertEquals(part1, refs[0].getPart(true));
//		assertEquals(part4, refs[1].getPart(true));
//		assertEquals(part5, refs[2].getPart(true));
//
//		// find input2 with MATCH_INPUT finds 1 editor: part7
//		refs = page.findEditors(input2, null, IWorkbenchPage.MATCH_INPUT);
//		assertEquals(1, refs.length);
//		assertEquals(part7, refs[0].getPart(true));
//
//		// find id1 with MATCH_ID finds 2 editors: part1 and part5 (in order)
//		refs = page.findEditors(null, id1, IWorkbenchPage.MATCH_ID);
//		assertEquals(2, refs.length);
//		assertEquals(part1, refs[0].getPart(true));
//		assertEquals(part5, refs[1].getPart(true));
//
//		// find id2 with MATCH_ID finds 2 editors: part4 and part7 (with part7
//		// first because it was active)
//		refs = page.findEditors(null, id2, IWorkbenchPage.MATCH_ID);
//		assertEquals(2, refs.length);
//		assertEquals(part7, refs[0].getPart(true));
//		assertEquals(part4, refs[1].getPart(true));
//
//		// find input1 and id1 with MATCH_INPUT and MATCH_ID finds 2 editors:
//		// part1 and part5 (in order)
//		refs = page.findEditors(input1, id1, IWorkbenchPage.MATCH_INPUT
//				| IWorkbenchPage.MATCH_ID);
//		assertEquals(2, refs.length);
//		assertEquals(part1, refs[0].getPart(true));
//		assertEquals(part5, refs[1].getPart(true));
//
//		// find input1 and id2 with MATCH_INPUT and MATCH_ID finds 1 editors:
//		// part4
//		refs = page.findEditors(input1, id2, IWorkbenchPage.MATCH_INPUT
//				| IWorkbenchPage.MATCH_ID);
//		assertEquals(1, refs.length);
//		assertEquals(part4, refs[0].getPart(true));
//	}
//
//
//	/**
//	 * Create and hide a single editor, and check it is reflected in the
//	 * editor references.  Check that close still works.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor1() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a.mock1", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor instanceof MockEditorPart);
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//		fActivePage.hideEditor(editorRef);
//		assertEquals(0, fActivePage.getEditorReferences().length);
//		fActivePage.showEditor(editorRef);
//		assertEquals(1, fActivePage.getEditorReferences().length);
//		fActivePage.closeAllEditors(true);
//		assertEquals(0, fActivePage.getEditorReferences().length);
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create and remove 2 editors.  Check that the removed editor
//	 * is not returned in the list of references.  Check that
//	 * close still works.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor2() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a.mock1", proj);
//		IFile file2 = FileUtil.createFile("a.mock2", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor instanceof MockEditorPart);
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//		IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
//		assertTrue(editor2 instanceof MockEditorPart);
//		IEditorReference editorRef2 = (IEditorReference) fActivePage.getReference(editor2);
//
//		fActivePage.hideEditor(editorRef);
//		IEditorReference[] refs = fActivePage.getEditorReferences();
//		assertEquals(1, refs.length);
//		assertEquals(editorRef2, refs[0]);
//		fActivePage.showEditor(editorRef);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(2, refs.length);
//
//		fActivePage.hideEditor(editorRef2);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(1, refs.length);
//		fActivePage.hideEditor(editorRef);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(0, refs.length);
//		fActivePage.showEditor(editorRef);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(editorRef, refs[0]);
//		fActivePage.showEditor(editorRef2);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(2, refs.length);
//
//		fActivePage.closeAllEditors(true);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(0, refs.length);
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create 2 editors and hide one.  When added back and then closed, there
//	 * should only be one editor.  Adding back the closed editor should
//	 * generate a log message and not effect the list of editors.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor3() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a.mock1", proj);
//		IFile file2 = FileUtil.createFile("a.mock2", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor instanceof MockEditorPart);
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//		IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
//		assertTrue(editor2 instanceof MockEditorPart);
//		IEditorReference editorRef2 = (IEditorReference) fActivePage.getReference(editor2);
//
//		fActivePage.hideEditor(editorRef2);
//		IEditorReference[] refs = fActivePage.getEditorReferences();
//		assertEquals(1, refs.length);
//		assertEquals(editorRef, refs[0]);
//		fActivePage.showEditor(editorRef2);
//		fActivePage.closeEditors(new IEditorReference[] { editorRef2 }, true);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(1, refs.length);
//		fActivePage.showEditor(editorRef2);
//		assertEquals(1, refs.length);
//		assertEquals(getMessage(), 1, logCount);
//		assertNotNull(getMessage());
//		assertTrue(getMessage().startsWith("adding a disposed part"));
//	}
//
//	/**
//	 * Create 2 editors, and remove and show one of them.  Trying to
//	 * add it a second time should not effect the list of editor references.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor4() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a.mock1", proj);
//		IFile file2 = FileUtil.createFile("a.mock2", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor instanceof MockEditorPart);
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//		IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
//		assertTrue(editor2 instanceof MockEditorPart);
//		IEditorReference editorRef2 = (IEditorReference) fActivePage.getReference(editor2);
//
//		fActivePage.hideEditor(editorRef2);
//		IEditorReference[] refs = fActivePage.getEditorReferences();
//		assertEquals(1, refs.length);
//		assertEquals(editorRef, refs[0]);
//		fActivePage.showEditor(editorRef2);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(2, refs.length);
//		fActivePage.showEditor(editorRef2);
//		refs = fActivePage.getEditorReferences();
//		assertEquals(2, refs.length);
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create 2 editors that effect the Content Outline view.  Make
//	 * sure that hiding and showing the active editor effects the
//	 * outline view.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor5() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a1.java", proj);
//		IFile file2 = FileUtil.createFile("a2.java", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//		IEditorPart editor2 = IDE.openEditor(fActivePage, file2);
//		assertTrue(editor2.getClass().getName().endsWith("CompilationUnitEditor"));
//
//		ContentOutline outline = (ContentOutline) fActivePage.showView(IPageLayout.ID_OUTLINE);
//		IPage page2 = outline.getCurrentPage();
//		fActivePage.activate(editor);
//		processEvents();
//		IPage page = outline.getCurrentPage();
//		assertFalse(page2==page);
//
//		assertEquals(getMessage(), 0, logCount);
//
//		fActivePage.hideEditor(editorRef);
//		assertEquals(page2, outline.getCurrentPage());
//		assertEquals(getMessage(), 0, logCount);
//
//		fActivePage.showEditor(editorRef);
//		assertEquals(page2, outline.getCurrentPage());
//		assertEquals(getMessage(), 0, logCount);
//
//		fActivePage.activate(editor);
//		assertEquals(page, outline.getCurrentPage());
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create one editor.  Make sure hiding and showing it effects
//	 * the outline view, and that when hidden the outline view
//	 * reflects the default page.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor6() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a1.java", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//
//		ContentOutline outline = (ContentOutline) fActivePage.showView(IPageLayout.ID_OUTLINE);
//		IPage defaultPage = outline.getDefaultPage();
//		assertNotNull(defaultPage);
//
//		processEvents();
//		IPage page = outline.getCurrentPage();
//		assertFalse(defaultPage==page);
//
//		assertEquals(getMessage(), 0, logCount);
//		assertEquals(0, partHiddenCount);
//		fActivePage.addPartListener(partListener2);
//		fActivePage.hideEditor(editorRef);
//		processEvents();
//
//		assertEquals(1, partHiddenCount);
//		assertEquals(editorRef, partHiddenRef);
//
//		assertEquals(defaultPage, outline.getCurrentPage());
//		//assertEquals(page, outline.getCurrentPage());
//		assertEquals(getMessage(), 0, logCount);
//
//		assertEquals(0, partVisibleCount);
//		fActivePage.showEditor(editorRef);
//		processEvents();
//		assertEquals(page, outline.getCurrentPage());
//		assertEquals(getMessage(), 0, logCount);
//		assertEquals(1, partVisibleCount);
//		assertEquals(editorRef, partVisibleRef);
//
//		fActivePage.activate(editor);
//		assertEquals(page, outline.getCurrentPage());
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create one editor.  Make sure hiding the editor updates
//	 * the window title.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor7() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a1.java", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//
//		processEvents();
//
//		String firstTitle = fWin.getShell().getText();
//
//		assertEquals(getMessage(), 0, logCount);
//		assertEquals(0, partHiddenCount);
//		fActivePage.addPartListener(partListener2);
//		fActivePage.hideEditor(editorRef);
//		processEvents();
//
//		assertEquals(1, partHiddenCount);
//		assertEquals(editorRef, partHiddenRef);
//
//		String nextTitle = fWin.getShell().getText();
//		String tooltip = editor.getTitleToolTip();
//		assertNotNull(tooltip);
//		String[] split = Util.split(nextTitle, '-');
//		assertEquals(2, split.length);
//		String nextTitleRebuilt = split[0] + "- " + tooltip + " -" + split[1];
//		assertEquals(firstTitle, nextTitleRebuilt);
//
//		assertEquals(0, partVisibleCount);
//		fActivePage.showEditor(editorRef);
//		processEvents();
//		assertEquals(getMessage(), 0, logCount);
//		assertEquals(1, partVisibleCount);
//		assertEquals(editorRef, partVisibleRef);
//		nextTitle = fWin.getShell().getText();
//		assertEquals(firstTitle, nextTitle);
//
//		fActivePage.activate(editor);
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create one editor.  Make sure hiding the editor that is the active part
//	 * causes another part to become active.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor8() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a1.java", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor.getClass().getName().endsWith("CompilationUnitEditor"));
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//
//		ContentOutline outline = (ContentOutline) fActivePage.showView(IPageLayout.ID_OUTLINE);
//		IPage defaultPage = outline.getDefaultPage();
//		assertNotNull(defaultPage);
//		fActivePage.activate(editor);
//
//		processEvents();
//		IPage page = outline.getCurrentPage();
//		assertFalse(defaultPage==page);
//
//		partActiveCount = 0;
//		partActiveRef = null;
//		assertEquals(getMessage(), 0, logCount);
//		assertEquals(0, partHiddenCount);
//		fActivePage.addPartListener(partListener2);
//		fActivePage.hideEditor(editorRef);
//		processEvents();
//
//		assertEquals(1, partHiddenCount);
//		assertEquals(editorRef, partHiddenRef);
//		assertEquals(1, partActiveCount);
//		assertFalse(partActiveRef == editorRef);
//
//		fActivePage.showEditor(editorRef);
//
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create a java editor.  Make a change.  Validate the enabled state
//	 * of some commands.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor9() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a1.java", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor.getClass().getName()
//				.endsWith("CompilationUnitEditor"));
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//
//		fActivePage.activate(editor);
//
//		processEvents();
//		ICommandService cs = (ICommandService) fActivePage.getWorkbenchWindow()
//				.getService(ICommandService.class);
//		Command undo = cs.getCommand("org.eclipse.ui.edit.undo");
//		assertTrue(undo.isDefined());
//
//		assertFalse(undo.isEnabled());
//
//		ITextEditor textEditor = (ITextEditor) editor;
//		IDocument doc = textEditor.getDocumentProvider().getDocument(
//				textEditor.getEditorInput());
//		doc.replace(0, 1, "  ");
//		fActivePage.saveEditor(editor, false);
//
//		processEvents();
//		assertTrue(undo.isEnabled());
//
//		assertEquals(getMessage(), 0, logCount);
//		fActivePage.hideEditor(editorRef);
//		processEvents();
//
//		assertFalse(undo.isEnabled());
//
//		fActivePage.showEditor(editorRef);
//
//		assertTrue(undo.isEnabled());
//
//		assertEquals(getMessage(), 0, logCount);
//	}
//
//	/**
//	 * Create and hide a single editor, and check it is reflected in the
//	 * editor references.  Check that closing the hidden editor still works.
//	 *
//	 * @throws Exception
//	 */
//	public void testOpenAndHideEditor10() throws Exception {
//		proj = FileUtil.createProject("testOpenAndHideEditor");
//		IFile file1 = FileUtil.createFile("a.mock1", proj);
//		IEditorPart editor = IDE.openEditor(fActivePage, file1);
//		assertTrue(editor instanceof MockEditorPart);
//		IEditorReference editorRef = (IEditorReference) fActivePage
//				.getReference(editor);
//		fActivePage.hideEditor(editorRef);
//		assertEquals(0, fActivePage.getEditorReferences().length);
//		fActivePage.showEditor(editorRef);
//		assertEquals(1, fActivePage.getEditorReferences().length);
//		fActivePage.hideEditor(editorRef);
//		processEvents();
//		fActivePage.closeAllEditors(false);
//		assertEquals(getMessage(), 0, logCount);
//		assertEquals(0, fActivePage.getEditorReferences().length);
//	}
//
//	/**
//	 * Test opening multiple editors for an edge case: one input.
//	 *
//	 * openEditors(IWorkbenchPage page, IFile[] inputs)
//	 */
//	public void testOpenEditors1() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditors");
//		IFile[] inputs = new IFile[1];
//		String fileName0 = "test0.txt";
//		inputs[0] = FileUtil.createFile(fileName0, proj);
//
//		// Check: editor references are returned for each file
//		IEditorReference[] refs = IDE.openEditors(fActivePage, inputs);
//		assertNotNull(refs);
//		assertEquals(1, refs.length);
//		assertNotNull(refs[0]);
//
//		// Check: the editor is materialized
//		IEditorPart editor0 = refs[0].getEditor(false);
//		assertNotNull(editor0);
//
//		// Check: the first file corresponds to the active editor
//		assertEquals(fActivePage.getActiveEditor(), editor0);
//
//		// Check: created editor match its input
//		assertEquals(editor0.getSite().getId(), fWorkbench.getEditorRegistry()
//				.getDefaultEditor(inputs[0].getName()).getId());
//
//		// Check: reference's title matches the file name
//		assertEquals(fileName0, refs[0].getTitle());
//	}
//
//	/**
//	 * Test opening multiple editors for three inputs. Only first editor
//	 * should be materialized; it also should be the active editor.
//	 *
//	 * openEditors(IWorkbenchPage page, IFile[] inputs)
//	 */
//	public void testOpenEditors3() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditors");
//		IFile[] inputs = new IFile[3];
//		String fileName1 = "test1.txt";
//		String fileName2 = "test2.txt";
//		String fileName3 = "test3.txt";
//		inputs[0] = FileUtil.createFile(fileName1, proj);
//		inputs[1] = FileUtil.createFile(fileName2, proj);
//		inputs[2] = FileUtil.createFile(fileName3, proj);
//
//		// Check: editor references are returned for each file
//		IEditorReference[] refs = IDE.openEditors(fActivePage, inputs);
//		assertNotNull(refs);
//		assertEquals(3, refs.length);
//		assertNotNull(refs[0]);
//		assertNotNull(refs[1]);
//		assertNotNull(refs[2]);
//
//		// Check: the first file got an editor materialized, rest of the files did not
//		IEditorPart editor0 = refs[0].getEditor(false);
//		assertNotNull(editor0);
//		assertNull(refs[1].getEditor(false));
//		assertNull(refs[2].getEditor(false));
//
//		// Check: the first file corresponds to the active editor
//		assertEquals(fActivePage.getActiveEditor(), editor0);
//
//		// Check: created editors match their inputs
//		assertEquals(editor0.getSite().getId(), fWorkbench.getEditorRegistry()
//				.getDefaultEditor(inputs[0].getName()).getId());
//
//		// Check: rest of the editors can be materialized
//		IEditorPart editor1 = refs[1].getEditor(true);
//		assertNotNull(editor1);
//
//		// Check: those editors match their inputs too
//		assertEquals(editor1.getSite().getId(), fWorkbench.getEditorRegistry()
//				.getDefaultEditor(inputs[1].getName()).getId());
//
//		// Check: reference's title matches the file name
//		assertEquals(fileName1, refs[0].getTitle());
//		assertEquals(fileName2, refs[1].getTitle());
//		assertEquals(fileName3, refs[2].getTitle());
//	}
//
//	/**
//	 * Test editor reuse when opening multiple editors. The internal editors
//	 * with matching {id, input} should be reused.
//	 *
//	 * openEditors(IWorkbenchPage page, IFile[] inputs)
//	 */
//	public void testOpenEditorsReuse() throws Throwable {
//		proj = FileUtil.createProject("testOpenEditors");
//
//		String fileName1 = "test1.txt";
//		String fileName2 = "test2.txt";
//		String fileName3 = "test3.txt";
//		int flag = IWorkbenchPage.MATCH_INPUT | IWorkbenchPage.MATCH_ID; // use both matches
//
//		// open three files
//		IFile[] inputs = new IFile[3];
//		inputs[0] = FileUtil.createFile(fileName1, proj);
//		inputs[1] = FileUtil.createFile(fileName2, proj);
//		inputs[2] = FileUtil.createFile(fileName3, proj);
//		IEditorReference[] refs = IDE.openEditors(fActivePage, inputs);
//
//		// open two of the same files in mixed order, 1st (materialized) and 3rd (not materialized)
//		String editorID = fWorkbench.getEditorRegistry().getDefaultEditor(inputs[0].getName()).getId();
//		IEditorInput[] inputs2 = new IEditorInput[] {
//				new FileEditorInput(inputs[1]),
//				new FileEditorInput(inputs[0]) };
//		String[] editorIDs2 = new String [] { editorID, editorID} ;
//
//		IEditorReference[] refs2 = fActivePage.openEditors(inputs2, editorIDs2, flag);
//		assertNotNull(refs2);
//		assertEquals(2, refs2.length);
//
//		// now input1 is materialized and has focus
//		IEditorPart editor = refs2[0].getEditor(false);
//		assertNotNull(editor);
//		assertEquals(fActivePage.getActiveEditor(), editor);
//
//		// check that the same editor was created
//		assertEquals(refs2[0].getEditor(true), refs[1].getEditor(true));
//		assertEquals(refs2[1].getEditor(true), refs[0].getEditor(true));
//
//		// open a file with different editor IDs, materialized (input0) and non-materialzed (input3)
//		String editorIDAlt = fWorkbench.getEditorRegistry().getDefaultEditor("abc.log").getId();
//		IEditorInput[] inputs3 = new IEditorInput[] {
//				new FileEditorInput(inputs[0]),
//				new FileEditorInput(inputs[2]) };
//		String[] editorIDs3 = new String [] { editorIDAlt, editorIDAlt} ;
//
//		IEditorReference[] refs3 = fActivePage.openEditors(inputs3, editorIDs3, flag);
//		assertNotNull(refs3);
//		assertEquals(2, refs3.length);
//
//		assertFalse(refs2[0].equals(refs[0]));
//		assertFalse(refs2[1].equals(refs[2]));
//	}
//
//	/**
//	 * A generic test to validate IWorkbenchPage's
//	 * {@link IWorkbenchPage#setPartState(IWorkbenchPartReference, int)
//	 * setPartState(IWorkbenchPartReference, int)} method which ensures the
//	 * prevention of regressing on bug 209333.
//	 */
//	public void testSetPartState() throws Exception {
//		// show a view
//		IViewPart view = fActivePage.showView(MockViewPart.ID);
//
//		// now minimize it
//		IViewReference reference = (IViewReference) fActivePage
//				.getReference(view);
//		fActivePage.setPartState(reference, IWorkbenchPage.STATE_MINIMIZED);
//
//		// since it's minimized, it should be a fast view
//		assertTrue("A minimized view should be a fast view", facade
//				.isFastView(fActivePage, reference));
//
//		// try to restore it
//		fActivePage.setPartState(reference, IWorkbenchPage.STATE_RESTORED);
//		// since it's maximized, it should not be a fast view
//		assertFalse("A restored view should not be a fast view", facade
//				.isFastView(fActivePage, reference));
//	}
//
//}
